﻿@charset "UTF-8";


/*
* 外部CSS読み込みω
*/

/* fonts */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@500;800&family=Noto+Sans+JP:wght@200;300;400;500;600;700;900&display=swap');

:root {
  --color-black: #000000;
  --color-beige: #F0ECD6;
  --color-BGgray: #EBEBEB;
}


body {
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
}

/* #header {
  display: none;
} */

.base_container {
  -webkit-box-sizing: border-box !important;
  -moz-box-sizing: border-box !important;
  -o-box-sizing: border-box !important;
  -ms-box-sizing: border-box !important;
    margin: 0 auto;
    font-size: 14px;
    line-height: 2;
}


.base_container * {
  -webkit-box-sizing: border-box !important;
  -moz-box-sizing: border-box !important;
  -o-box-sizing: border-box !important;
  -ms-box-sizing: border-box !important;
  color: #000000;
  font-weight: 500;
  font-size: 15px;
  line-height: 2;
  font-family: 'Noto Sans JP', sans-serif;
}
.base_container .spacer100 {
	height: 100px;
}
.base_container img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
}
.base_container h2 {
	background-color: transparent !important;
}
.base_container h3 {
	border-bottom: 0px !important;
}

.base_container h2,
.base_container h3,
.base_container h4 {
  font-family: 'Noto Sans JP', sans-serif;
}

.base_container p,
.base_container ul {
  font-family: 'Noto Sans JP', sans-serif;
  padding: 0;
  margin: 0;
  font-weight: 500;
}

.base_container li {
  list-style: none;
}

.base_container a {
  font-family: 'Noto Sans JP', sans-serif;
  transition: ALL .6s ease;
  -webkit-transition: ALL .6s ease;
  -moz-transition: ALL .6s ease;
  -o-transition: ALL .6s ease;
  text-decoration: none;
}


.base_container br.sp {
  display: none;
}

.base_container br.pc {
  display: inline;
}

.base_container .pc_hide {
  display: none;
}

.base_container .sp_hide {
  display: block;
}

.base_container .pc {
  display: block;
}

.base_container .sp {
  display: none;
}

/* 共通 */
.base_container .flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .base_container {
    width: 100%;
    padding: 0;
    font-size: 4vw;
  }
  .base_container p,
  .base_container ul {
    font-size: 0.9em;
  }
  .base_container br.sp {
    display: inline;
  }

  .base_container br.pc {
    display: none;
  }

  .base_container .pc_hide {
    display: block;
  }

  .base_container .sp_hide {
    display: none;
  }

  .base_container .pc {
    display: none;
  }

  .base_container .sp {
    display: block;
  }
}

/*--------------------------------

>>> wrap

---------------------------------*/
.base_container .wide__wrap {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 4;
}

.base_container .wrap {
  max-width: 700px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .base_container .wide__wrap {
    width: 100%;
    padding: 0;
    margin: 0 auto;
  }

  .base_container .wrap {
    width: 100%;
    margin: 0 auto;
  }
}

.base_container .slideUp {
	opacity: 0;
	transform: translateY(20px);
	transition:ALL .8s ease;
}
.base_container .slideUp.started {
	opacity: 1;
	transform: translateY(0px);
}

.base_container .btn {
	display: block;
	width: 510px;
	text-align: center;
	padding: 23px 0;
	background: #fff;
	border: 1px solid #000;
	color: #000;
	font-size: 1em;
	letter-spacing: 0.02em;
	line-height: 1;
	text-decoration: none;
	transition: ALL .8s ease;
	margin: 50px auto 50px !important;
	-webkit-transition: ALL .8s ease;
	-moz-transition: ALL .8s ease;
	-o-transition: ALL .8s ease;
	position: relative;
  }
  .base_container .btn:hover {
	background: #000 !important;
	color: #fff !important;
	opacity: 1;
  }
  @media (max-width: 520px) {
	.base_container .btn_container {
	  text-align: center;
	  margin: 80px auto;
	  padding: 0 20px;
	}
	.base_container .btn {
	  display: block;
	  width: 90%;
	  font-size: 1em;
	  line-height: 1;
	  margin: 50px auto 50px !important;

	}
  }

  .tab-menu {
	margin-bottom: 0;
	display: flex;
	justify-content: center;
  }
  
  .tab-menu .tab_btn {
	display: block;
	width: 400px;
	padding: 10px 20px;
	margin-right: 0;
	border: none;
	background-color: #fff;
	cursor: pointer;
	border: 2px solid #cfbcbb;
	color: #cfbcbb;
	font-size: 1.3rem;
	letter-spacing: .05em;
  }
  
  .tab-menu .tab_btn.active {
	background-color: #cfbcbb;
	color: #fff;
  }

  @media (max-width: 520px) {
	.tab-menu .tab_btn {
		display: block;
		width: 100%;
		font-size: 1rem;
		letter-spacing: .05em;
	  }
	
  }

/*--------------------------------

>>> FV

---------------------------------*/
.base_container .fv {
  position: relative;
  height: auto;
}
@media (max-width: 768px) {
	.base_container .fv {
		width: 100%;
		aspect-ratio: 1/1;
	}
	.base_container .fv img.bg {
		width: 100%;
		height: 100%;
		object-fit: cover !important;
		object-position: center !important;
		position: absolute !important;
		top: 0;
		left: 0;
		z-index: 2;
	}
}

.base_container .read {
	padding: 75px 0;
}
.base_container .read h2 {
	text-align: center !important;
	font-weight: 700 !important;
	letter-spacing: .05em !important;
	font-size: 2.5em !important;
}
.base_container h2 span {
    /* background: linear-gradient(transparent 50%, #DDD4C7 0%); */
    display: block !important;
    padding: 0 2px 4px !important;
	font-size: .5em !important;
	letter-spacing: .05em !important;
	font-weight: 600 !important;
}

.base_container .read h2 + p {
	text-align: center;
	font-weight: 400;
	font-size: 1em;
	margin-top: 35px;
}
.base_container .read .info {
	text-align: center;
	width: 550px;
	margin: 75px auto 0;
	padding: 35px 0;
	border-radius: 60px 0 0 0;
	background-color: #DDD4C7;
	position: relative;
}
.base_container .read .info::after {
	content: "";
	display: block;
	width: 150px;
	height: 150px;
	background: url(img/info_obj.png) center center/contain no-repeat;
	position: absolute;
	top: -50px;
	right: -50px;
}
.base_container .read .info p {
	margin: 0;
	padding: 0;
	line-height: 1;
	font-weight: 400;
}
.base_container .read .info p:nth-of-type(1) {
	font-size: 1em;
}
.base_container .read .info p:nth-of-type(2) {
	margin-top: 15px;
	position: relative;
}
.base_container .read .info p:nth-of-type(2) span {
	position: relative;
	font-size: 2.2em;
	letter-spacing: .1em;
	font-weight: 600;
	position: relative;
}
.base_container .read .info p:nth-of-type(2) span::before {
	content: "";
	width: 100%;
	height: 1px;
	background-color: #000000;
	position: absolute;
	top: calc(100% + 5px);
	left: 0;
}
.base_container .read .info p:nth-of-type(3) {
	font-size: 1.2em;
	font-weight: 700;
	margin-top: 15px;
	line-height: 1.5;
	letter-spacing: .05em;
}
.base_container .read .info p:nth-of-type(4) {
	font-size: 1em;
	margin-top: 35px;
	line-height: 2;
}
.base_container .read .info a {
	display: inline-block;
	text-align: center;
	margin-top: 35px;
	padding: 10px 50px;
	background-color: #fff;
	color: #B29E83;
	border-radius: 100px;
	transition:ALL .5s ease;
}
.base_container .read .info a:hover {
	opacity: 0.5;
}
@media (max-width: 768px) {
	.base_container .read {
		padding: 50px 5%;
	}
	.base_container .read h2 {
		font-size: 1.7em !important;
	}

	.base_container .read h2 + p {
		font-size: 3.5vw;
	}
	.base_container .read .info {
		width: 100%;
		margin: 75px auto 0;
		padding: 35px 5%;
		border-radius: 40px 0 0 0;
	}
	.base_container .read .info::after {
		width: 100px;
		height: 100px;
		right: -2.5%;
	}
	.base_container .read .info p:nth-of-type(1) {
		font-size: 1em;
	}
	.base_container .read .info p:nth-of-type(2) {
		margin-top: 15px;
		position: relative;
	}
	.base_container .read .info p:nth-of-type(2) span {
		position: relative;
		font-size: 1.6em;
	}
	.base_container .read .info p:nth-of-type(2) span::before {
		top: calc(100% + 3px);
	}
	.base_container .read .info p:nth-of-type(3) {
		font-size: 1em;
	}
	.base_container .read .info p:nth-of-type(4) {
		font-size: .9em;
	}
	.base_container .read .info a {
		padding: 10px 20px;
	}
	

}

.base_container .top_rank {
}
.base_container .rank01 {
}
.base_container .top_rank .rank_block + .rank_block {
	margin-top: 100px;
}
.base_container .top_rank .rank_block .card {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	background-color: #fff;
	border-radius: 6px;
	padding: 30px 0 30px 60px;
}
.base_container .top_rank .rank_block.rank01 {
	background-color: #cfbcbb;
	padding: 30px 0;
}
.base_container .top_rank .rank_block.rank02 .card {
	background-color: #c5bcb6;
}
.base_container .top_rank .rank_block.rank03 .card {
	background-color: #cdcdcd;
}
.base_container .top_rank .rank_block.rank04 .card {
	background-color: #E8E8E8;
}
.base_container .top_rank .rank_block.rank05 .card {
	background-color: #E8E8E8;
}
.base_container .top_rank .rank_block .card .thumb {
	width: 270px;
	position: relative;
	background-color: #fff;
}
.base_container .top_rank .rank_block .card .thumb .rankmark{
	display: none;
}
.base_container .top_rank .rank_block .card .thumb span.bland {
	display: block;
	width: 100%;
	position: absolute;
	bottom: 3%;
	right: calc(100% + 2em);
	text-align: right;
	transform: rotate(90deg);
	transform-origin: right bottom;
	font-weight: 700;
	color: #000;
}
/* .base_container .top_rank .rank_block.rank02 .card .thumb span.bland,
.base_container .top_rank .rank_block.rank03 .card .thumb span.bland {
	color: #fff;
} */
.base_container .top_rank .rank_block .card .thumb span.en_name {
	display: block;
	width: 110%;
	position: absolute;
	top: -1.5em;
	left: 100%;
	transform: rotate(90deg);
	transform-origin: left bottom;
	font-weight: 700;
	color: #000;
	text-align: left;
}
/* .base_container .top_rank .rank_block.rank02 .card .thumb span.en_name,
.base_container .top_rank .rank_block.rank03 .card .thumb span.en_name {
	color: #fff;
} */
.base_container .top_rank .rank_block .card .txt {
	width: calc(100% - 270px);
	text-align: center;
}
.base_container .top_rank .rank_block .card .txt img {
	width: auto !important;
	height: 100px !important;
	margin: 0 auto;
}
.base_container .top_rank .rank_block .card .txt h2 {
	text-align: center;
	margin: 25px 0 0 !important;
	font-size: 1.7em !important;
	font-weight: 700;
	padding: 25px 0 0;
	line-height: 1.3;
	position: relative;
}
.base_container .top_rank .rank_block .card .txt h2::before {
	content: "";
	display: block;
	width: 100px;
	height: 1px;
	background-color: #000;
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
}
.base_container .top_rank .rank_block .card .txt .price {
	text-align: center;
	margin: 15px 0 0;
	padding: 0;
	font-size: 1.7em !important;
	font-weight: 700;
	line-height: 1;
}
.base_container .top_rank .rank_block .card .txt a {
	display: inline-block;
	background-color: #000;
	border: 1px solid #000;
	color: #fff !important;
	border-radius: 10px;
	text-align: center;
	margin: 20px 0 0 !important;
	padding: 5px 50px;
	font-size: 1.1em;
	letter-spacing: .05em;
}
.base_container .top_rank .rank_block .card .txt a:hover {
	background-color: #fff;
	color: #000 !important;
}
.base_container .top_rank .rank_block .card .txt a + p {
	line-height: 1.3;
	margin-top: 10px;
	letter-spacing: .05em;
	color: red;
}
.base_container .top_rank .rank_block .card .txt a + p span {
	font-size: .9rem;
	color: red;
}
.base_container .top_rank .rank_block h3 {
	font-size: 1em;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
.base_container .top_rank .rank_block h3 span {
	font-size: 1.2em;
	letter-spacing: .1em;
	position: relative;
}
.base_container .top_rank .rank_block h3 span::before {
	content: "";
	display: block;
	width: 1000%;
	height: .5px;
	background-color: #000;
	position: absolute;
	top: 50%;
	left: calc(100% + 15px);
}
@media (max-width: 768px) {
	.base_container .top_rank .rank_block {
		padding: 75px 5%;
	}
	.base_container .top_rank .rank_block.rank01 {
		padding: 30px 5%;
	}
	
	.base_container .top_rank .rank_block + .rank_block {
		margin-top: 100px;
		padding: 0 5%;
	}	
	.base_container .top_rank .rank_block .card {
		padding: 30px 50px 30px 50px;
	}	
	.base_container .top_rank .rank_block .card .thumb {
		width: 100%;
		background-color: transparent;
	}
	.base_container .top_rank .rank_block .card .thumb .thumb_inner {
		background-color: #fff;
	}
	.base_container .top_rank .rank_block .card .thumb .rankmark{
		display: block;
		width: auto !important;
		margin: 0 auto 20px;
		height: 80px !important;
	}
	.base_container .top_rank .rank_block .card .txt {
		width: 100%;
	}
	.base_container .top_rank .rank_block .card .txt h2 {
		font-size: 1.3em !important;
		line-height: 1.3;
	}
	.base_container .top_rank .rank_block .card .txt img {
		display: none;
	}
	.base_container .top_rank .rank_block .card .txt .price {
		font-size: 1.3em !important;
	}

	.base_container .top_rank .rank_block .card .thumb span.bland {
		font-size: 3.3vw;
	}
	.base_container .top_rank .rank_block .card .thumb span.en_name {
		font-size: 3.3vw;
		white-space: nowrap;
		top: 80px;
	}	
	.base_container .top_rank .rank_block h3 {
		font-size: 3.2vw;
	
	}
	
}


.base_container .top_rank .rank_block .review {
	margin-top: 35px;
}
.base_container .top_rank .rank_block .review .review_item {
	margin-top: 25px;
}
.base_container .top_rank .rank_block .review .review_item + .review_item {
	margin-top: 25px;
}
.base_container .top_rank .rank_block .review p.name {
	display: inline-block;
	font-size: .9em;
	letter-spacing: .05em;
	position: relative;
}
.base_container .top_rank .rank_block .review .hukidashi {
	border-radius: 15px;
	background-color: #EAD7D6;
	padding: 15px;
	margin-top: 5px;
	position: relative;
}

.base_container .top_rank .rank_block.rank01 .review .hukidashi {
	background-color: #fff;
}
.base_container .top_rank .rank_block.rank02 .review .hukidashi {
	background-color: #E0D7D1;
}
.base_container .top_rank .rank_block.rank03 .review .hukidashi {
	background-color: #f0e9e3;
}
.base_container .top_rank .rank_block.rank04 .review .hukidashi {
	background-color: #E8E8E8;
}
.base_container .top_rank .rank_block.rank05 .review .hukidashi {
	background-color: #E8E8E8;
}

.base_container .top_rank .rank_block .review .hukidashi p {
	font-size: .9em;
	font-weight: 400;
}
@media (max-width: 768px) {
	.base_container .top_rank .rank_block .review p.name {
		font-size: 3vw;
	}
	.base_container .top_rank .rank_block .review .hukidashi {
		margin-top: 5px;
	}	
	.base_container .top_rank .rank_block .review .hukidashi p {
		font-size: 3vw;
		line-height: 1.7;
	}
}


.base_container .top_rank .rank_block .styling {
	margin-top: 35px;
}
.base_container .top_rank .rank_block .styling .flex {
	margin-top: 35px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.base_container .top_rank .rank_block .styling .flex .f_item {
	width: 48%;
	position: relative;
}
/* .base_container .top_rank .rank_block .styling .flex .f_item a {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
} */
.base_container .top_rank .rank_block .styling .flex .f_item a:hover {
	background-color: rgba(255, 255, 255, .5);
}
.base_container .top_rank .rank_block .styling .thumb a img {
	transition:ALL .5s ease;
}
.base_container .top_rank .rank_block .styling .thumb a:hover img {
	opacity: 0.5;
}
.base_container .top_rank .rank_block .styling .staff_meta {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
	margin-top: 25px;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_photo {
	width: 80px;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_photo .inner {
	width: 80px;
	height: 80px;
	border-radius: 80px;
	background-color: #fff;
	position: relative;
	overflow: hidden;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_photo .inner img {
	width: 100%;
	height: 100%;
 	object-fit: cover;
 	object-position: center;
    position: absolute;
    top: 0;
    left: 0;
}
.base_container .top_rank .rank_block .styling  .staff_meta .staff_photo .inner a img {
	transition:ALL .5s ease;
}
.base_container .top_rank .rank_block .styling  .staff_meta .staff_photo .inner a:hover img {
	opacity: 0.5;
}

.base_container .top_rank .rank_block .styling .staff_meta .staff_info {
	width: calc(100% - 80px);
	padding-left: 25px;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_info p {
	font-size: .9em;
	letter-spacing: .05em;
	margin: 0;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_info p.bland {
	font-size: .8em;
}
.base_container .top_rank .rank_block .styling .staff_meta .staff_info p.shop {
	font-size: 1.1em;
}
@media (max-width: 768px) {
	.base_container .top_rank .rank_block .styling .staff_meta {
		margin-top: 10px;
	}
	.base_container .top_rank .rank_block .styling .staff_meta .staff_photo {
		display: none;
	}
	.base_container .top_rank .rank_block .styling .staff_meta .staff_info {
		width: 100%;
		padding-left: 0;
	}
	.base_container .top_rank .rank_block .styling .staff_meta .staff_info p {
		font-size: 2.8vw;	
	}
	.base_container .top_rank .rank_block .styling .staff_meta .staff_info p.bland {
		font-size: 2.6vw;
	}
	.base_container .top_rank .rank_block .styling .staff_meta .staff_info p.shop {
		font-size: 3.2vw;
	}
}

.base_container .lowrank {
	margin-top: 100px;
}
.base_container .lowrank h2 {
	display: flex;
	justify-content: center !important;
	align-items: center !important;
	text-align: center !important;
	font-weight: 600 !important;
	letter-spacing: .05em !important;
	line-height: 1.3 !important;
	height: 2em !important;
	font-size: 1rem !important;
	margin-bottom: 20px !important;
}
.base_container .lowrank .container {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 30px;
}
.base_container .lowrank .container .item {
}
.base_container .lowrank .container .item .thumb {
	padding: 0 40px;
}
.base_container .lowrank .container .item p {
	text-align: center;
	margin-top: 20px;
}
.base_container .lowrank .container .item a {
	display: block;
	width: 150px;
	background-color: #000;
	border-radius: 10px;
	color: #fff !important;
	text-align: center;
	margin-inline: auto;
	letter-spacing: .3em;
	margin-top: 30px !important;
	border: 1px solid #000;
	transition: ALL .5s ease;
}
.base_container .lowrank .container .item a:hover {
	background-color: #fff;
	color: #000 !important;
}
@media (max-width: 768px) {
	.base_container .lowrank .container .item .thumb {
		padding: 0;
	}
	
}


.base_container .attention {
	margin-top: 100px;
	padding: 75px 0;
}
.base_container .attention .container {
	width: 100%;
	display: block;
}
.base_container .attention .container .inner {
	background-color: #f5f5f5;
	padding: 50px;
	border-radius: 10px;
}
.base_container .attention h2 {
	text-align: center;
	font-weight: 600;
	letter-spacing: .05em;
	font-size: 1rem;
	margin-bottom: 20px !important;
}
.base_container .attention li {
	font-size: .9rem;
	text-align: center;
}
@media (max-width: 768px) {
	.base_container .attention {
		margin-top: 50px;
	}	
	.base_container .attention .container .inner {
		padding: 50px 2.5%;
	}
	
}


/* バナーエリア */
.base_container .bnr_area .bnr_box a img {
	transition:ALL .5s ease;
}
.base_container .bnr_area .bnr_box a:hover img {
	opacity: 0.5;
}



.base_container .other {
	margin-top: 100px;
}
.base_container .other h3 {
	font-size: 1em;
	margin: 0;
	padding: 0;
	overflow: hidden;
}
.base_container .other h3 span {
	font-size: 1.2em;
	letter-spacing: .1em;
	position: relative;
}
.base_container .other h3 span::before {
	content: "";
	display: block;
	width: 1000%;
	height: .5px;
	background-color: #000;
	position: absolute;
	top: 50%;
	left: calc(100% + 15px);
}

.base_container .other .grid {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 75px;
}
.base_container .other .grid .g_item {
	text-align: center;
	width: calc(50% - 15px); /* Adjust for spacing */
	margin-bottom: 50px; /* Maintain row gap */
}
.base_container .other .grid .g_item img {
	display: block;
	width: 100%;
	height: auto;
}
.base_container .other .grid .g_item h4 {
	margin: 15px 0 0 !important;
	font-size: 1.2em !important;
	font-weight: 700;
	line-height: 1.3;
	margin-bottom: 10px !important;
}
.base_container .other .grid .g_item a.btn {
	display: inline-block;
	width: auto !important;
	background-color: #000;
	border: 1px solid #000;
	color: #fff !important;
	border-radius: 10px;
	text-align: center;
	margin: 20px 0 0 !important;
	padding: 10px 50px;
	font-size: 1.1em;
	letter-spacing: .05em;
}
.base_container .other .grid .g_item a.btn:hover {
	background-color: #fff !important;
	color: #000 !important;
}

@media (max-width: 768px) {

	.base_container .other h3 {

		font-size: 3.2vw;

	}
.base_container .other .grid .g_item h4 {

	font-size: .9em !important;

}

}
