@charset "utf-8";

/*=================================================================================================================================*/
/** 個別指定 for スマートフォン
/*=================================================================================================================================*/

/*---------------------------------------------
 ** 740px
---------------------------------------------*/
@media screen and (max-width: 740px) {

	/*---------------------------------------------
	body
---------------------------------------------*/
	html {
		scroll-behavior: smooth;
	}

	body {
		font-size: 14px;
		line-height: 1.8;
		border: none;
		padding-bottom: 60px;
	}

	p {
		font-size: 15px;
	}

	.only_pc_none {
		display: block !important;
	}

	.only_sp_none {
		display: none !important;
	}

	.sp_br {
		display: inline;
	}

	/*画像*/
	img {
		max-width: 100%;
		height: auto;
	}

	header #sns {
		display: none;
	}


	/* navi */

	#js-mmenu-wrap {
		display: block !important;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 3;
	}

	.sp_navi {
		font-size: 16px;
		font-weight: bold;
		color: #fff;
		line-height: 44px;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		width: 100%;
		height: 44px;
		padding: 0 50px;

	}

	.sp_navi.fixed {
		position: fixed;
		top: 0;
		left: 0;
	}

	.footer.fixed {
		position: fixed;
		bottom: 0;
		left: 0;
	}

	.sp_navi a {
		display: block;
		width: 28px;
		height: 25px;
		padding: 14px 10px;
		margin: 2px;
		position: absolute;
		background: #ccc;
		top: 6px;
		left: 6px;
	}

	.sp_navi a:before,
	.sp_navi a:after {
		content: '';
		display: block;
		background: #fff;
		height: 3px;
	}

	.sp_navi a span {
		background: #fff;
		display: block;
		height: 3px;
		margin: 8px 0;
	}


	#luxy {
		margin-top: 70px;
	}




	.menu {
		display: none !important;
	}

	.f_sns {
		width: 100%;
		display: block;
		background: rgba(255, 255, 255, 0.8);
		padding: 15px 0;
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 9999;
		border-top: 1px solid #a7afaa;
	}

	.f_sns ul {
		width: 95%;
		max-width: 350px;
		display: flex;
		justify-content: space-between;
		margin: 0 auto;
	}

	.f_sns ul li {
		width: 12%;
		max-width: 38px;
	}

	#header {
		position: unset;
	}

	#header h1 {
		width: 70%;
		max-width: 170px;
		margin: 0 auto;
		padding: 10px 0;
		position: absolute;
		right: 0;
		left: 0;
		top: 3px;
	}

	#header h1 a {
		width: 100%;
		padding: 0;
	}

	.furelte_ban {
		display: none;
	}

	#home #main {
		position: relative;
	}

	#main_furelte {
		width: 100%;
		display: block;
		position: absolute;
		bottom: 0;
		text-align: center;
		background: #cccccc78;
	}

	#main_furelte a {
		width: 100%;
		max-width: 480px;
		display: block;
		margin: 0 auto;
	}

	#sp_nav_furelte {
		padding-left: 0 !important;
	}

	#sp_nav_furelte a {
		width: 80%;
		display: block;
		position: absolute;
		padding: 0 !important;
		bottom: -100px;
		left: 0;
		right: 0;
		margin: 0 auto;
	}


	.ttl_bg {
		min-height: 500px;
	}

	#main_ashiya {
		min-height: 320px;
		background: url(../img/salon/main_ashiya.jpg) no-repeat top center;
		background-size: 160% auto !important;
		margin-top: 70px;
	}

	#main_maternity {
		min-height: 240px;
		margin-top: 50px;
	}

	#main_maternity h2 {
		padding-top: 60%;
	}

	.ttl_bg h2 {
		font-size: 160%;
		padding: 30% 0;
	}

	#home .ttl_bg h2 {
		font-size: 160%;
		padding: 100px 0;
	}

	.img_box {
		height: 300px;
		margin-bottom: 3%;
	}

	.con h3 {
		font-size: 120%;
		padding-bottom: 5%;
	}

	#menu_f h3 {
		font-size: 130% !important;
		margin-top: 20px;
	}

	#menu_f .p_center_bold {
		font-size: 110%;
	}

	.img_box img {
		width: 150%;
		max-width: 150%;
	}

	.p_center {
		text-align: left;
		line-height: 2;
	}

	.s_center {
		text-align: center;
		margin-bottom: 50px;
	}

	.p_center_pink {
		font-family: "Noto Sans JP", sans-serif;
		font-size: 100%;
		color: #cf8fa3;
		text-align: left;
	}

	#menu_e .p_center {
		text-align: center;
	}

	#menu_e .p_center_first {
		text-align: left;
	}

	#menu_e .p_center_mata {
		text-align: left;
	}


	/* モーダルCSS */


	div[class^="modalWrapper"] {
		position: absolute;
		top: 50vh;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 95%;
		max-width: 900px;
		padding: 30px 10px;
		background-color: #fff;
		box-sizing: border-box;
		margin: 0 auto;
	}

	div[class^="modalWrapper"] h3 {
		font-size: 160% !important;
		font-family: "Noto Sans JP", sans-serif !important;
	}

	.modalWrapper p,
	.modalWrapper2 p {
		font-size: 80% !important;
		text-align: left;
	}




	.p_center_bold {
		font-size: 100%;
		line-height: 1.8;
		text-align: center !important;
	}

	.p_flex>div img {
		width: 100%;
		margin-bottom: 5px;
	}

	.p_flex>div p {
		bottom: -1.5em;
		right: 0;
	}

	.staff_appo {
		width: 100%;
	}

	.staff_appo h4 {
		font-size: 120%;
	}

	.staff_appo p {
		text-align: left;
		font-size: 90%;
	}

	.staff_appo ul li {
		font-size: 100%;
	}

	.staff_appo p:nth-of-type(2) {
		text-align: center;
	}


	.line_double {
		width: 100%;
		padding: 6% 2% 4%;
	}

	.line_double h4 {
		margin-top: 15px;
		margin-bottom: 10px;
	}

	.line_double p {
		text-align: left;
		font-size: 90%;
	}

	.line_double ul li {
		text-align: left;
	}

	.line_double h4 span {
		font-size: 100%;
	}

	.line_double h4.h4_line {
		margin-top: 10px;
		margin-bottom: 10%;
	}

	#menu_f .line_double h4 {
		font-size: 110%;
	}

	.line_double_electro {
		width: 100%;
	}

	.line_double_electro h3 {
		margin-top: 5% !important;
	}

	.electro_obi {
		font-size: 110%;
		background: #a7afaa;
		color: #fff;
		text-align: center;
		padding: 5px 10px;
		box-sizing: border-box;
		line-height: 1.4;
	}

	.electro_bold {
		font-size: 110%;
	}

	.line_double_electro ul li {
		text-align: left;
	}

	.p_underline {
		margin-bottom: 15% !important;
	}

	.plan_short,
	.plan_set_position {
		padding-top: 50px !important;
	}

	.plan_short::before {
		content: "お手軽ショートプラン";
		white-space: pre;
		width: 250px;
		height: 30px;
		border-radius: 15px;
		display: block;
		font-size: 110%;
		line-height: 1.2;
		padding-top: 5px;
		text-align: center;
		font-family: "Noto Serif JP", serif;
		color: #fff;
		box-sizing: border-box;
		background: #c6c0b8;
		display: inline-block;
		position: absolute;
		top: 1%;
		right: 0;
		left: 0;
		margin: 0 auto;
	}

	.plan_set::before,
	.plan_set_position::before {
		content: "1番お得なセットプラン";
		white-space: pre;
		width: 250px;
		height: 30px;
		border-radius: 15px;
		display: block;
		font-size: 110%;
		line-height: 1.2;
		padding-top: 5px;
		text-align: center;
		font-family: "Noto Serif JP", serif;
		color: #fff;
		box-sizing: border-box;
		background: #c6c0b8;
		display: inline-block;
		position: absolute;
		top: 1%;
		right: 0;
		left: 0;
		margin: 0 auto;
	}

	.foot_bg {
		padding: 5% 0;
	}

	.foot_bg ul {
		display: block;
	}

	.foot_copy {
		display: block;
	}

	.foot_copy p {
		font-size: 100%;
	}

	#pageTop {
		position: fixed;
		bottom: 77px;
		right: 0px;
		z-index: 9199;
	}

	#pageTop a {
		width: 40px;
		height: 40px;
		opacity: 0.9;
	}

	#pageTop a:hover {
		opacity: 0.9;
	}

	#ank01,
	#ank02,
	#ank03,
	#ank04,
	#ank05,
	#ank06,
	#ank07,
	#ank08,
	#ank09,
	#ank10 {
		padding-top: 50px !important;
		margin-top: 0px !important;
	}

	#home #ank01 {
		padding-top: 300px !important;
		margin-top: -300px !important;
	}


	#menu_e #ank07 {
		padding-top: 300px !important;
		margin-top: -300px !important;
	}

	#menu_f #ank01 {
		padding-top: 70px !important;
		margin-top: 0px !important;
	}

	#salon #ank01,
	#salon #ank02 {
		padding-top: 320px !important;
		margin-top: -320px !important;
	}


	.data_table tr {
		display: flex;
		flex-wrap: wrap;
	}


	.data_table tr th {
		width: 100%;
		display: block;
		background: #dbe0dc;
	}


	.data_table tr th.va_top {
		vertical-align: middle;
		padding-top: 10px;
	}


	.data_table tr td {
		width: 100%;
		display: block;
		padding: 15px 15px;
	}

	.data_table tr td ::before {
		width: 3px;
	}
}

@media screen and (max-width: 480px) {
	.ttl_bg {
		min-height: 380px;
	}

	#home .ttl_bg {
		min-height: 500px;
	}

	#menu_d .ttl_bg,
	#news .ttl_bg,
	#privacy .ttl_bg,
	#tokutei .ttl_bg {
		min-height: 200px;
	}

	#school .ttl_bg {
		min-height: 200px;
	}

	#main_headspa {
		background-size: 140% auto !important;
		min-height: 290px;
	}

	#main_headspa h2 {
		padding: 27% 0 5%;
		font-size: 160%;
	}



	#main_maternity h2 {
		padding: 20% 0 5%;
	}

	.lower .con h3 {
		font-size: 120%;
	}

	#news .ttl_bg h2 {
		font-size: 120%;
		line-height: 2.2;
	}

	#menu_d .ttl_bg h2,
	#news .ttl_bg h2 {
		padding: 15% 0;
	}

	#school .ttl_bg h2 {
		padding: 15% 0 0;
	}

	#news .ttl_bg h2 span {
		font-size: 160%;
		font-family: "Noto Serif JP", serif;
	}

	#school .ttl_bg h2 {
		font-size: 120%;
		line-height: 3;
	}

	#school .ttl_bg h2 span {
		font-size: 130%;
	}

	#privacy .ttl_bg h2,
	#tokutei .ttl_bg h2 {
		font-size: 160% !important;
		padding: 20% 0 0;
	}

	#tokutei .ttl_bg h2 {
		font-size: 120% !important;
		letter-spacing: 0;
		padding-top: 80px;
	}

	.gal-3 li {
		width: 90%;
		margin: 0 auto 5%;
	}

	.gal-3 li:nth-child(3n) {
		margin-right: auto;
	}

	.data_table {
		font-size: 95%;
	}

	.data_table p,
	.data_table div {
		font-size: 95%;
	}

	.data_table p,
	.data_table div {
		font-size: 92%;
	}

	.data_table tr td ul li {
		text-indent: -2.2em;
		margin-left: 1.2em;
	}

	.salon_data table tr th {
		width: 85px;
	}

	.salon_data table tr td {
		width: calc(100% - 95px);
	}

	.salon_data table tr td dl {
		display: block;
	}

	.salon_data table tr td dl dt,
	.salon_data table tr td dl dd {
		width: 100%;
	}

	.price_scroll {
		min-height: 120px;
	}

	.price_tbl table {
		width: 700px;
	}

	.price_p p {
		font-size: 140%;
	}

	.price_p table {
		width: 100% !important;
		border-spacing: 20px 10px !important;
	}

	.price_p table th {
		width: 60%;
		font-size: 130%;
	}

	.price_p table td {
		font-size: 130%;
		font-family: "Noto Serif JP", serif;
		letter-spacing: 0.1em;
		vertical-align: top;
		line-height: 1.6;
	}

	.price_p table+p span:nth-of-type(2) {
		margin-top: -10px;
	}

	.school_course {
		max-width: 300px;
	}

	.school_course>div {
		width: 100%;
	}

	.school_course>div:nth-of-type(2) img:nth-of-type(1) {
		margin-bottom: 5%;
	}

	.school_maternity h4 {
		margin-top: 60px;
		text-align: center;
	}

	.school_mate_price,
	#school .line_double p {
		text-align: center;
	}

.school-add{
font-size:90%;
margin-left:-1em;
margin-right:-1em;
}

	.therapist-course {
		padding: 5px;
	}

	.privacy_read {
		margin-bottom: 10%;
	}

	#privacy dl {
		margin-bottom: 10%;
	}

	.foot_copy p:nth-child(2) {
		text-align: left;
	}

	#pageTop {
		bottom: 79px;
	}

	#home footer {
		margin-top: 20% !important;
	}

	#menu_b footer,
	#menu_c footer,
	#menu_e footer,
	#school footer,
	#privacy footer,
	#tokutei footer {
		margin-top: 40px !important;
	}

	.lower footer {
		margin-top: 40px !important;
	}

	.yomogi_option {
		font-size: 90%;
	}

	.yomogi_option::before {
		top: -20px;
	}

	.pink_btn a {
		padding: 0.8% 8% 1.5% 3%;
		font-size: 80%;
	}

	.pink_btn a::before {
		right: 10px;
	}

	.pink_btn a::after {
		right: 17px;
	}

	p.meguru {
		background: url(../img/menu/menu_yomogi02.jpg) no-repeat center top 10px;
		background-size: 220px auto;
		padding: 220px 0 5% 0;
	}

	.yomogi_plus {
		font-size: 85%;
	}

	.yomogi_plus .col_3 dl {
		font-size: 100%;
		width: 100%;
	}

	.yomogi_plus h4:before,
	.yomogi_plus h4:after {
		width: 20px;
	}

	.yakuzen_soup {
		font-size: 85%;
	}

	.yakuzen_soup h4+p {
		text-align: left;
	}

	.yomogi_option {
		width: 100%;
		padding: 4% 3% 5%;
		font-size: 80%;
	}

	.pink_underline {
		font-size: 13px;
	}

	.yomogi_img p {
		font-size: 75%;
	}

}

@media screen and (max-width: 340px) {
	.img_box {
		height: 200px;
		margin-bottom: 1%;
	}

	#main_headspa {
		min-height: 340px;
	}

	.foot_bg p {
		font-size: 90%;
	}

	.foot_bg ul {
		font-size: 95%;
	}



	.data_table p,
	.data_table div {
		font-size: 90%;
	}


	.yomogi_option {
		font-size: 70%;
	}

	#menu_f h3 {
		font-size: 110% !important;
	}

	#menu_f .p_center_bold {
		font-size: 90%;
	}

	.pink_underline {
		font-size: 12px;
	}

	.yomogi_plus h4 {
		font-size: 10px;
	}

	.yomogi_plus h4:before,
	.yomogi_plus h4:after {
		width: 15px;
	}
}

/* スマホのときのみ電話をかける */
@media (min-width: 740px) {
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}