@charset "utf-8";

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
html {
	font-size: 16px;
}
p,a,h1,h2,h3,h4,h5,li,dt,dd{
  	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;	
	color: #333;	
	text-decoration: none;
}
p,dt,dd,li,a {
	font-size: 1rem;
	line-height: 2rem;
	font-feature-settings: "palt";
	list-style: none;
}
.sp_br {
	display: none;
}
img {
	width: 100%;
	vertical-align: bottom;
}
#top,article {
	width: 100%;	
	max-width: 1920px;
	margin: 0 auto;
	background: #B2FFFF;	
}
article {
	padding: 80px 0;
}
#top > div {
  position: relative;
  z-index: 10;
  width: 100%;
  height: 1100px;
}
.toplogo img {
	width: 30%;
	padding: 30px 5px 0;
	max-width: 320px;
	position: absolute;	
	top: 0;
	left: 10%;	
  	z-index: 100;	
	background: #fff;
}
.topimg img {
	width: 70%;
	max-width: 800px; 
	position: absolute;	
	top: 0;
	right: 0;
}
.topimg::after {
  	content: "";
  	position: absolute;
  	right:0;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	max-width: 800px;
	background: url(../images/maru1.svg);
	background-repeat: no-repeat;
	background-position: top right;
	background-size: contain;
}
.message {
	max-width: 550px;
	padding: 10px 0;
  	position: absolute;
	top: 420px;
	left: 10%; 
}
.topimg_btm {
	width: 50%;
	max-width: 650px; 
	position: absolute;	
	bottom: 0;
	left: 10%;
	filter: drop-shadow(2px 10px 4px #2F5252);	
}
.news {
	width: 50%;
	max-width: 650px; 
	position: absolute;	
	bottom: 10%;
	right: 5%;	
}
/*h2*/
.title,.title_zebra,.title_zebra_w {
	font-size: 2rem;
	padding-bottom: 10px;
	line-height: 3rem;
	font-weight: 900;
}
.title_zebra_w {
	color: #fff;
}
.kana {
	font-size: 1.6rem;
}
.title_zebra::after {
  	content: "";
  	display: block;
  	width: 43px;
	height: 37px;
	margin: 10px auto;	
  	background: url(../images/zebra.svg);
  	background-size: cover;
}
.title_zebra_w::after {
  	content: "";
  	display: block;
  	width: 43px;
	height: 37px;
	margin: 10px auto;	
  	background: url(../images/zebra_w.svg);
  	background-size: cover;
} 
/*Instagram*/
#insta {
	width: 100%;
	max-width: 1920px;		
	margin: 0 auto;
	text-align: center;
}
#insta > div {
	display: flex;
}
#insta > div > p {
	width: calc(100% / 4);
	border: solid 1px #B2FFFF;
}
#mind,#set_manu,#price,#profile {
	width: calc(100% - 20px);
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}
#wrap > article:nth-of-type(3),#wrap > article:nth-of-type(5) {
	background: #E34393;
}
/*お客様に満足して頂く為に*/
#mind > p {
	margin-bottom: 20px;
}
#mind > div {
	display: flex;
	justify-content: space-between;
}
.mind_box {
	width: 32%;
	display: flex;
	flex-direction: column;		
	border: solid 2px #E34393;
}
.mind_box > h3 {
	padding: 10px;
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	background: #E34393;
}
.mind_box > p {
	flex-grow: 1;
	padding: 10px;
	text-align: left;
	background: #fff;	
}
/*メニュー表*/
#set_manu > ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.menu_jp,.menu_en {
	width: 48%;
	padding: 10px;
	text-align: left;
}
.menu_jp > h3,.menu_en > h3 {
	font-weight: 900;
	color: #fff;	
}
.menu_jp > p,.menu_en > p {
	color: #fff;	
}
.menu_en > p {		
	font-size: 0.8rem;
	line-height: 1.5rem;
}

/*price*/
#price > div {
	display: flex;
	justify-content: space-between;	
	flex-wrap: wrap;
}
#price > div > ul {
	width: 50%;
	text-align: left;
}
#price > div > ul > li {
	display: flex;
	justify-content: space-between;	
}
#price > div > ul > li > p:last-of-type {
	width: 180px;
}
#price > div > ul > li > p:first-of-type > span {
	margin-bottom: 15px;
	display: block;
	font-size: 0.8rem;
}
#price > div > ul > h3 {
	font-weight: 900;
	font-size: 1.3rem;
	line-height: 3rem;
}
.price_txt {	
	font-size: 0.8rem;
	line-height: 1.5rem;
}

/*プロフィール*/
.prof_box {
	display: flex;
	justify-content: center;
}
.prof_box_l {
	width: 30%;
	padding: 10px;	
	max-width: 300px;
}
.prof_box_r {
	padding: 10px;
}
.profile_name {
	margin-bottom: 20px;
	font-size: 2rem;
	font-weight: 900;
	color: #fff;
	text-align: left;	
}
.profile_name > span {
	font-size: 0.8rem;
	font-weight: 400;
}
.prof_box_r > ul {
	margin-bottom: 20px;
}
.prof_box_r > ul li {
	margin-left: 2rem;
	list-style: disc;
	color: #fff;
	text-align: left;
}
.profile_txt {
	text-align: left;	
	color: #fff;
}

/*ポップアップ*/
.popup_btn {
	line-height: 1.3rem;
	margin: 10px 0;
	padding: 5px 8px;	
	display: inline-block;
  	border: 1px solid #fff;
  	color: #fff;
  	transition-duration: 0.3s;
}
.popup_btn:hover {
  background: #cc3d85;
  color: #ffffff;
}
.remodal_box {
	display: flex;
	flex-wrap: wrap;
}

.remodal_box > ul {
	width: 50%;
	padding: 10px;
}
.remodal_box > ul > h4 {
	margin-bottom: 5px;
	padding: 5px;
	background: #B2FFFF;
}
.remodal_box > ul > li {
	text-align: left;
	font-size: 0.8rem;
	line-height: 1.3rem;
}
/*footer*/
footer {
	padding: 50px 0;
	background: #333;
}
.add_box {
	display: flex;
	justify-content: center;
	align-items: center;
}
.logo {
	width: 25%;
	margin-right: 20px;
	max-width: 200px;
}
.add > a, .add > p{
	color: #fff;	
	font-size: 0.8rem;	
	line-height: 1.2rem;	
	
}
.sns_box {
	padding: 10px;
	display: flex;
}

.sns_link > a  {
	margin-left: 10px;
	display: inline-block;
	font-size: 0.8rem;
	line-height: 1.2rem;
	color: #fff;
}
.icon {
	width: 2rem;
	padding-right: 10px;
}

@media (max-width: 480px){
	html {
		font-size: 12px;
	}
	p,a,h1,h2,h3,h4,h5,li,dt,dd{
		font-weight: 500;	
	}	
	.sp_br {
		display: block;
	}
	/*h2*/
	.title,.title_zebra,.title_zebra_w {
		font-weight: 700;
	}	
	.title_zebra::after,.title_zebra_w::after  {
		width: 25px;
		height: 22px;
		margin: 10px auto;
	}	
	#top > div {
	  position: relative;
	  z-index: 10;
	  width: 100%;
	  height: 700px;
	}	
	.topimg::after {
		width: 70%;
		height: 70%;
	}
	.toplogo img {
		width: 30%;
		padding: 20px 5px 0;
		left: 0;	

	}	
	article {
		padding: 50px 0;
	}
	.message {
		width: calc(100% - 20px);
		padding: 0 0 0 20px;
		top: 320px;
		left: 0; 
	}
	.topimg_btm {
		width: 150px;
		top: 180px;
		left: 20px;
		filter: drop-shadow(2px 5px 4px #2F5252);	
	}	
	.news {
		width: calc(100% - 20px);
		padding: 0 20px 0 0;
		bottom: 0;
		right: 0;	
	}
	#mind > div {
		display: block;
	}	
	.mind_box {
		width: 100%;
		margin-bottom: 10px;
	}	
	.mind_box > h3,.mind_box > p  {
		padding: 8px;
	}
	.menu_jp, .menu_en,#price > div > ul {
    	width: 100%;
	}
	#price > div > ul > li > p:last-of-type {
		width: 80px;
	}
	.prof_box {
		display: block;
	}
	.prof_box_l {
		width: 100%;
		max-width: 200px;
		margin: 0 auto;
	}
	.profile_name {
		text-align: center;
	}
	.add_box {
		width: calc(100% - 20px);
		margin: 0 auto;
		flex-wrap: wrap;
	}
	.logo {
		width: 100%;
		margin: 0 auto 20px;
		max-width: 100px;
	}
}