@charset "UTF-8";
/* sp(320px) */

/* 私たちがお応えします！ */
#kaiketsu {
	background-image: url(../img/home/bg_kaiketsu_sp.jpg);
	background-repeat: no-repeat;
	background-position: 50% 100%;
	background-size: cover;
	padding-block-start: 40px;
	position: relative;
}
#kaiketsu::after {
	content: '';
	width: 30px;
	height: 15px;
	background: #eaeaea;
	display: inline-block;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	position: absolute;
	inset: 0 auto auto 50%;
}

#kaiketsu .inner {
	position: relative;
}
#kaiketsu .ph {
	position: relative;
	padding-inline-start: 4%;
	display: grid;
	align-items: end;
/*	border: 1px solid #000;*/
}
#kaiketsu .ph figure {
	max-inline-size: 443px;
/*	border: 1px solid red;*/
}
#kaiketsu .txt {
	padding-block-start: 0em;
	padding-inline-end: 7%;
	line-height: 2;
}
#kaiketsu .txt p span {
	font-weight: bold;
	background:linear-gradient(transparent 70%, #faf225 30%);
}

/* たくさんの喜びの声をいただいております */
#voices {
	background-color: #fffed7;
}
#voices .hl_top {
	inline-size: auto;
	margin-inline: auto;
}
#voices .hl_top > span.enc {
	display: block;
	font-size: 15px;
	text-align: center;
	padding-inline-start: 0em;
	margin-block-end: .5em;
}
#voices .hl_top .sub,
#voices .hl_top .sub2 {
	position: relative;
}
#voices .hl_top .sub:before,
#voices .hl_top .sub:after {
	content: '';
	width: 1.5em;
	border-top: 1px solid #000;
	position: absolute;
	top: .7em;
}
#voices .hl_top .sub:before {	
	transform: rotate(55deg);
	left: -1.6em;	
}
#voices .hl_top .sub:after {
	transform: rotate(-55deg);
	right: -1.5em;
}
#voices .hl_top .sub2:before,
#voices .hl_top .sub2:after {
	content: '';
	width: 0.8em;
	border-top: 1px solid #000;
	position: absolute;
	top: 1.1em;
}
#voices .hl_top .sub2:before {	
	transform: rotate(45deg);
	left: -1.4em;	
}
#voices .hl_top .sub2:after {
	transform: rotate(-45deg);
	right: -1.3em;
}

/* スライド */
#voices li {
	background-color: #fff;
	border: 2px solid #f4f4f4;
	border-radius: .8em;
	padding: 1.2em 1.4em;
}
#voices li .name {
	display: grid;
	grid-template-columns: 39px auto;
	grid-template-rows: auto;
	column-gap: .5em;
	row-gap: 0;
	align-items: center;
}
#voices li .name > div{
	font-size: 16px;
	font-weight: bold;
	line-height: 1.4;
	border-block-end: 3px solid #c9e8ff;
}
#voices li .ttl {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.4;
	color: #4eaaf1;
	padding-block: .4em;
}

/* よくある質問 */
#faq {
	background-color: #f4f4f4;
}
#faq dl dt {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.4;
	color: #4eaaf1;
	padding-block-end: 1.2em;
	position: relative;
	padding-inline-start: 40px;
}
#faq dl dd {
	margin-inline-start: 0;
	position: relative;
	padding-inline-start: 40px;
}
#faq dl dd:not(:last-of-type) {
	padding-block-end: 2em;
	border-block-end: 1px dotted #7f7f7f;
	margin-block-end: 2em;
}
#faq dl dt:before,
#faq dl dd:before {
	font-family: "Manrope", sans-serif;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.0;
	text-align: center;
	border-radius: 50%;
	inline-size: 1.4em;
	block-size: 1.4em;
	display: grid;
	place-items: center; 

	position: absolute;	
	inset: -.1em auto auto 0;
}

#faq dl dt:before {
	content: 'Q';
	color: #fff;
	background-color: #4eaaf1;
}
#faq dl dd:before {
	content: 'A';
	color: #4eaaf1;
	background-color: #fff;
}

/* ご来店お待ちしております！ */
#contact .hl {
	font-size: 20px;
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
}
#contact .hl span {
	position: relative;
}
#contact .hl span:before,
#contact .hl span:after {
	content: '';
	width: 1.6em;
	border-top: 1px solid #000;
	position: absolute;
	top: .9em;
}
#contact .hl span:before {	
	transform: rotate(55deg);
	left: -1.6em;	
}
#contact .hl span:after {
	transform: rotate(-55deg);
	right: -1.5em;
}
#contact .sub {
	font-size: 13px;
	line-height: 1.4;
	text-align: center;
	font-weight: normal;
	margin-block-start: 1em;
}

#contact ul {
	display: grid;
	grid-template-columns: auto;
	grid-template-rows: auto;
	column-gap: 0;
	row-gap: 0;
}
#contact li {
	border: 3px solid #f4f4f4;
	border-radius: .8em;
	padding: 1.5em 1.5em;

	margin-block-end: 1em;
}
#contact li .name {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.4;
	position: relative;
}
#contact li .name {
	padding-inline-end: 1.7em;
	cursor: pointer;
}
#contact li .name br.mbr {
	display: none;
}
#contact li .name span {
	display: grid;
	place-items: center; 
	position: absolute;
	inset: .2em 0 auto auto;
	font-size: 12px;
	color: #fff;
	background-color: #24c5b8;
	line-height: 1;
	border-radius: 50%;
	block-size: 1.8em;
	inline-size: 1.8em;
}
#contact li .in {
	display: none;
}


#contact li figure {
	inline-size: 100%;
	margin-block-start: 1.3em;
}
#contact li .phone {
	display: none;
	grid-template-columns: 16px auto;
	grid-template-rows: auto;
	column-gap: .2em;
	row-gap: 0;
	margin-block-start: 1.1em;
}
#contact li .phone a {
	color: #000;
}
#contact li .phone a:hover {
	text-decoration: none;
}

#contact li .sp_btn {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto;
	column-gap: 1.5%;
	row-gap: 0;
	margin-block-start: 1.1em;
	padding-block-end: .8em;
}
#contact li .sp_btn a {
	display: block;
}


#contact li .icn {
	position: relative;
	inset-block-start: .28em;
}
#contact li .num {
	font-family: "Manrope", sans-serif;
	font-size: 22px;
	font-weight: bold;
	line-height: 1;
}
#contact li .time {
	margin-block-start: .2em;
}
#contact li .gmap iframe {
	block-size: 200px;
	margin-block-start: 1.0em;
}
#contact li .adr {
	margin-block-start: .2em;
}
#contact li a.reserve {
	display: none;
	inline-size: 75%;
	margin-inline: auto;
	background-color: #24c5b8;
	color: #fff;
	border-radius: .2em;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	line-height: 3;
	margin-block-start: 1.1em;
}
#contact li a.reserve:hover {
	text-decoration: none;
}



@media handheld, print, screen and (min-width: 375px) {
/* iphone6 */


/* end of media query(iphone6) */	
}



@media handheld, print, screen and (min-width: 414px) {
/*  iPhone6 Plus */

/* end of media query(iPhone6 Plus) */	
}



@media handheld, print, screen and (min-width: 480px) {
/* tablet */

/* たくさんの喜びの声をいただいております */
#voices .hl_top {
	inline-size: 19em;
	margin-inline: auto;
}
#voices .hl_top > span.enc {
	font-size: 20px;
	text-align: left;
	padding-inline-start: 1em;
	margin-block-end: 0;
}

/* よくある質問 */
#faq dl dt {
	font-size: 18px;
	padding-inline-start: 45px;
}
#faq dl dd {
	padding-inline-start: 45px;
}
#faq dl dt:before,
#faq dl dd:before {
	font-size: 22px;
}

/* ご来店お待ちしております！ */
#contact .hl {
	font-size: 24px;
}
#contact .sub {
	font-size: 14px;
}

#contact ul {
	grid-template-columns: repeat(2, 1fr);
	column-gap: 3%;
	row-gap: 0;
}
#contact li {
	border: 3px solid #f4f4f4;
	padding: 1.5em 1.5em;
	margin-block-end: 1.5em;
}
#contact li .name {
	font-size: 17px;
}

#contact li .name {
	padding-inline-end: 0;
	cursor: auto;
}
#contact li .name span {
	display: none;
	place-items: center; 
	position: absolute;
	inset: .2em 0 auto auto;
	font-size: 12px;
	color: #fff;
	background-color: #24c5b8;
	line-height: 1;
	border-radius: 50%;
	block-size: 1.8em;
	inline-size: 1.8em;
}
#contact li .in {
	display: block;
}

#contact li .phone {
	display: grid;
	grid-template-columns: 16px auto;
	column-gap: .2em;
	row-gap: 0;
}
#contact li .sp_btn {
	display: none;
}
#contact li .icn {
	inset-block-start: .28em;
}
#contact li .num {
	font-size: 22px;
}
#contact li a.reserve {
	display: block;
}

	@media (-webkit-min-device-pixel-ratio: 2){
		

	/* end of media query(retina) */	
	}

/* end of media query(tablet) */	
}



@media handheld, print, screen and (min-width: 620px) {
/* iPad */

/* 私たちがお応えします！ */
#kaiketsu {
	background-image: url(../img/home/bg_kaiketsu.jpg);
	padding-block-start: 20px;
}
#kaiketsu::after {
	width: 40px;
	height: 18px;
}
#kaiketsu .ph {
	padding-inline-start: 4%;
}
#kaiketsu .ph figure {
	max-inline-size: 443px;
}
#kaiketsu .txt {
	padding-block-start: 4em;
	padding-inline-end: 2%;
	padding-inline-start: 1em;
}

/* たくさんの喜びの声をいただいております */
#voices .hl_top {
	inline-size: 18em;
}
#voices .hl_top > span.enc {
	font-size: 22px;
}

/* スライド */
#voices li {
	border: 2px solid #f4f4f4;
	padding: 1.2em 1.4em;
}
#voices li .name {
	grid-template-columns: 39px auto;
	column-gap: .5em;
}
#voices li .name > div{
	font-size: 17px;
	border-block-end: 3px solid #c9e8ff;
}
#voices li .ttl {
	font-size: 17px;
}

/* よくある質問 */
#faq dl dt {
	font-size: 18px;
	padding-inline-start: 50px;
}
#faq dl dd {
	padding-inline-start: 50px;
}
#faq dl dt:before,
#faq dl dd:before {
	font-size: 24px;
}

/* ご来店お待ちしております！ */
#contact .hl {
	font-size: 28px;
}
#contact .sub {
	font-size: 15px;
}



/* end of media query(iPad) */	
}



@media handheld, print, screen and (min-width: 900px) {
/* pc */

/* 私たちがお応えします！ */
#kaiketsu {
	background-image: url(../img/home/bg_kaiketsu.jpg);
	padding-block-start: 80px;
}
#kaiketsu::after {
	width: 50px;
	height: 22px;
}
#kaiketsu .ph {
	padding-inline-start: 4%;
}
#kaiketsu .ph figure {
	max-inline-size: 443px;
}
#kaiketsu .txt {
	padding-block-start: 4em;
	padding-inline-end: 7%;
	padding-inline-end: 4%;
	padding-inline-start: 2em;
}

/* たくさんの喜びの声をいただいております */
#voices .hl_top > span.enc {
	font-size: 26px;
}
/* スライド */
#voices li {
	border: 2px solid #f4f4f4;
	padding: 1.2em 1.4em;
}
#voices li .name {
	grid-template-columns: 39px auto;
	column-gap: .5em;
}
#voices li .name > div{
	font-size: 18px;
	border-block-end: 3px solid #c9e8ff;
}
#voices li .ttl {
	font-size: 18px;
}

/* よくある質問 */
#faq dl dt {
	font-size: 20px;
	padding-inline-start: 50px;
}
#faq dl dd {
	padding-inline-start: 50px;
}
#faq dl dt:before,
#faq dl dd:before {
	font-size: 26px;
}

/* ご来店お待ちしております！ */
#contact .hl {
	font-size: 32px;
}
#contact .sub {
	font-size: 16px;
}


#contact ul {
	grid-template-columns: repeat(3, 1fr);
	column-gap: 3%;
	row-gap: 0;
}
#contact li .name br.mbr {
	display: inline-block;
}

/* end of media query(pc) */
}


@media handheld, print, screen and (min-width: 1040px) {
/* pc */

/* 私たちがお応えします！ */
#kaiketsu .txt {
	padding-inline-start: 0;
}


/* end of media query(pc) */
}