@charset "utf-8";
/******************************
共通機構
*******************************/
/**** 骨格 *****/
main{
	text-align: center;
	margin:auto;
	box-sizing:border-box;
}
section{
	text-align: left;
	margin: auto;
	box-sizing: border-box;
}

/****TOPページ****/
/****swiper****/
.swiper-container{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
	border-radius: 0;
}
.swiper-slide {
   height: 100%;
}
.swiper-slide img{
  width: 100%;
  object-fit: cover;
}
@media screen and (max-width: 699px) {
	.smpdtp{
		padding-top: 95px;
	}
	.swiper-container, .swiper-slide img{
    height: 220px;
  }
}
@media screen and (min-width: 700px) {
  .swiper-container, .swiper-slide img{
    height: 500px;
  }
}
@media screen and (min-width: 1280px) {
}

#TPmn > div.bgclrgreen{
	padding: 0 0 4.5em;
}
.leafTP{
	margin: auto;
}
.leafTP img{
	width: 100%;
	object-fit: cover;
	object-position: center;
}
@media screen and (max-width: 699px) {
}
@media screen and (min-width: 700px) {
}
@media screen and (min-width: 900px) {
	.leafTP img{
		width: 100%;
		height: 170px;
		object-fit: cover;
		object-position: center;
	}
}
@media screen and (min-width: 1980px) {
	.leafTP img{
		width: 100%;
		height: auto;
	}
}

.MNcntr{
	margin: auto;
}
.MNcntr > div:first-child {
	background: hsl(0, 0%, 100%);
	border-radius: 1em;
}
.MNcntr > div:nth-child(2) {
	background: hsl(0, 0%, 100%);
	border-radius: 1em;
}
.MNcntr > div:last-child {
	background: hsl(0, 0%, 100%);
	border-radius: 1.5em;
}

.MNcntr > div:first-child h2 img{
	width: 85%;
}
@media screen and (max-width: 899px) {
	.MNcntr > div:first-child dl.comdtl > dd{
		text-align: left;
	}
}
@media screen and (min-width: 900px) {
	.MNcntr > div:first-child dl.comdtl{
		flex-direction: column;
	}
	.MNcntr > div:first-child dl.comdtl dt{
		text-align: center;
		width: 100%;
	}
	.MNcntr > div:first-child dl.comdtl dt span{
		min-width: 80px;
		padding: auto 1em;
		display: inline-block;
	}
	.MNcntr > div:first-child dl.comdtl > dd{
		width: 100%;
		text-align: center;
		margin-bottom: 1em;
	}
}

.MNcntr > div:nth-child(2) h2{
	color: hsl(0, 0%, 100%);
	font-weight: normal;
	text-align: center;
	padding: 0 2.5em;
	margin-bottom: .5em;
	border-radius: .8em;
	background: hsl(86, 51%, 60%);
	display: inline-block;
}
h2.tpcstit strong{
	color: hsl(0, 0%, 100%);
	font-weight: normal;
	letter-spacing: .2em;
	line-height: 100%;
	padding: .7em 30px .7em 75px;
	margin: 0 auto .5em;
	border-radius: .8em;
	background: url(../img/tp/icon_bird01.svg), url(../img/sbbg/blue02.jpg);
	background-repeat: no-repeat, repeat;
	background-position: left 20px center, left center;
	background-size: 50px auto, auto;
	display: inline-block;
}
h2.tpcstit span{
	font-size: .6em;
	letter-spacing: 0;
	display: block;
}
@media screen and (max-width: 899px) {
	h2.tpcstit{
		text-align: center;
	}
}
@media screen and (min-width: 900px) {
	h2.tpcstit{
		text-align: left;
	}
}


.calendar-wrapper {
  width: 100%;
  height: 320px;
  overflow: hidden;
}
.MNcntr > div:nth-child(2) iframe{
	width: 125%;
	height: 400px;
  transform: scale(0.8);
  transform-origin: top left;
	vertical-align:top;
	box-sizing: border-box;
}
@media screen and (max-width: 899px) {
	.MNcntr{
		width: 88%;
    padding: 0;
    display: flex;
    flex-direction: column;
  }
  .MNcntr > div{
		padding: 1.3em 5%;
		margin: 1em 0;
  }
}
@media screen and (min-width:900px) {
  .MNcntr{
		text-align: center;
		width: 800px;
		margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
		grid-template-rows: 5fr 4fr;
		column-gap: 40px;
 		row-gap: 20px;
  }
	.MNcntr > div:first-child {
		padding: 1.3em;
		grid-column: 1/2;
		grid-row: 1/3;
	}
	.MNcntr > div:nth-child(2) {
		padding: 1.3em;
		grid-column: 2/3;
		grid-row: 1;
	}
	.MNcntr > div:last-child {
		padding: 1.3em;
		grid-column: 2/3;
		grid-row: 2;
	}
	.MNcntr > div:nth-child(2) > a{transition: all  ease-out .3s;}
	.MNcntr > div:nth-child(3) > a{transition: all  ease-out .3s;}
	.MNcntr > div:last-child > a{transition: all  ease-out .3s;}
}

[id^="udrtile"] {
  text-align: center;
  position: relative;
  width: 100%;
  background: url(../img/sbbg/tile01.jpg);
  background-position: center top;
  border: none;

  mask-image: linear-gradient(#000, #000), url(../img/sbbg/norenbtm.svg);
  mask-repeat: no-repeat, repeat-x;
  mask-position: top center, bottom center;
  mask-size: 100% 100%, 50px 25px;
  mask-mode: alpha;
  mask-composite: exclude;

  -webkit-mask-image: linear-gradient(#000, #000), url(../img/sbbg/norenbtm.svg);
  -webkit-mask-repeat: no-repeat, repeat-x;
  -webkit-mask-position: top center, bottom center;
  -webkit-mask-size: 100% 100%, 50px 25px;
  -webkit-mask-composite: xor;
  -webkit-mask-mode: alpha;

  z-index: 1;
}
#udrtiletop{
	padding: 2.5em 0 4em;
}
#udrtilesub{
	padding: 5em 0 7.5em;
}
[id^="udrtile"] h2{
	font-size: 1.2em;
	line-height: 135%;
	margin: 0 0 1.5em;
}
[id^="udrtile"] h2 > span{
	padding: .3em 4em;
	background: url(../img/tp/icon_star01.svg), url(../img/tp/icon_star02.svg);
	background-position: left center, right center;
	background-repeat: no-repeat, no-repeat;
	background-size: auto 100%, auto 100%;
	display: inline-block;
}
#udrtiletop h2 img{
	padding: 0 .5em;
	vertical-align:bottom;
}
@media screen and (max-width: 899px) {
	#udrtiletop h2{
		letter-spacing: 0;
		padding: .3em 1em;
	}
	[id^="udrtile"] h2 > span{
		background-size: 45px auto, 45px auto;
	}
	.nMAP{
		width: 80%;
		margin: auto;
	}
	.nMAP iframe{
		width: 100%;
		height: 200px;
	}
}
@media screen and (min-width:900px) {
	#udrtiletop h2{
		letter-spacing: .1em;
	}
}

ul.point3{
	padding: 0;
	margin: 0 auto;
	list-style: none;
	display: flex;
}
ul.point3 li{
	padding: 1em;
	margin: 0;
}
ul.point3 li > div{
	width: 100%;
	padding: .6em;
	background: url(../img/sbbg/green01.jpg);
	border-radius: 50%;
	position: relative;
	aspect-ratio: 1 / 1;
}
ul.point3 li > div > img{
	object-fit: cover;
}
ul.point3 li > div > img:first-child{
	width: 100%;
	border-radius: 50%;
	aspect-ratio: 1 / 1;
}
ul.point3 li > div > img:last-child{
	position: absolute;
	top: -.7em;
	left: -.7em;
}
ul.point3 dl dt{
	color: hsl(1, 88%, 71%);
	font-weight: bold;
	line-height: 135%;
	margin: 1em 0 .5em;
}
ul.point3 dl dd{
	text-align: left;
	line-height: 150%;
	padding: 0 .5em;
}
@media screen and (max-width: 899px) {
	ul.point3{
		width: 75%;
		margin: auto;
		flex-direction: column;
	}
	ul.point3 dl dt{
		font-size: 1.35em;
	}
	ul.point3 dl dd{
		font-size: 1.1em;
		text-align: center;
		padding: 0;
	}
}
@media screen and (min-width:900px) {
	ul.point3{
		width: 700px;
		flex-direction: row;
		flex-wrap: wrap;
	}
	ul.point3 li{
		width: calc(100% / 3);
	}
	ul.point3 dl dd{
		font-size: .75em;
	}
}


[class^="noren"]{
	height: 26px;
}
[id^="gMAP"]{
	position: relative;
	height: 400px;
}
[id^="gMAP"] > div{
	width: 100%;
	position: absolute;
	top: -25px;
	overflow: hidden;
}
[id^="gMAP"] > div iframe{
	width: 100%;
}
#gMAPtop, #gMAPtop > div iframe{
	height: 450px;
}
#gMAPsub, #gMAPsub > div iframe{
	height: 250px;
}
@media screen and (max-width: 899px) {
	#gMAPtop, #gMAPtop > div iframe{
		height: 300px;
	}
	[id^="udrtile"] iframe{
		width: 100%;
	}
}
@media screen and (min-width:900px) {
}

/****固定ページGREENなど****/
[class^="SPimg"]{
	overflow: hidden;
}
[class^="SPimg"] img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
@media screen and (max-width: 699px) {
	[class^="SPimg"]{
		height: 190px;
	}
	.SPimg01{
		height: 280px;
	}
}
@media screen and (min-width: 700px) {
	[class^="SPimg"]{
		height: 370px;
	}
	.SPimg01{
		height: 790px;
	}
}
@media screen and (min-width: 1280px) {
	[class^="SPimg"]{
		height: 470px;
	}
	.SPimg01{
		height: 790px;
	}
}


.pageTP{
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
	border-radius: 0;
}
.pageTP img{
  width: 100%;
  object-fit: cover;
	object-position: center;
}
@media screen and (max-width: 699px) {
	.pageTP{
		padding-top: 95px;
  }
	.pageTP img{
    height: 150px;
  }
}
@media screen and (min-width: 700px) {
	.pageTP img{
    height: 300px;
  }
}
@media screen and (min-width: 1280px) {
}
[id^="ktpg"]{
	font-family: "Kosugi Maru", sans-serif;
	text-align: center;
	color: hsl(0, 0%, 40%);
	padding: 3em 0 1em;
	margin: 0;
}
[id^="ktpg"] h1 strong{
	font-weight: normal;
	line-height: 135%;
	display: block;
}
[id^="ktpg"] h1 span{
	font-weight: normal;
	line-height: 135%;
}
[id^="ktpg"] h1 strong > span{display: none;}
#ktpggreen h1 > span{color: hsl(86, 51%, 60%);}
#ktpgpink h1 > span{color: hsl(1, 82%, 70%);}
#ktpgblue h1 > span{color: hsl(173, 78%, 45%);}
#ktpgyellow h1 > span{color: hsl(26, 94%, 61%);}
#ktpgyellow2 h1 > span{color: hsl(1, 82%, 70%);}
#ktpgpurple h1 > span{color: hsl(283, 30%, 49%);}

@media screen and (max-width: 899px) {
	[id^="ktpg"]{
		padding: 2em 0 1em;
		background: url(../img/sbbg/town02.svg?1) no-repeat center bottom;
		background-size: 100% auto;
	}
	[id^="ktpg"] h1 strong{
		font-size: 1.3em;
	}
}
@media screen and (min-width: 900px) {
	[id^="ktpg"]{
		background: url(../img/sbbg/town01.svg?1) no-repeat center bottom;
		background-size: 1980px auto;
	}
	[id^="ktpg"] h1 strong{
		font-size: 1.6em;
	}
}

[class^="bgclr"]{
	text-align: center;
	padding: 3em 0 4.5em;
	background-size: 950px 25px, auto
}
[class^="bgclr"] > div.whtboard{
	margin: auto;
	background: hsl(0, 0%, 100%);
	border-radius: 1em;
}
.bgclrgreen{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/green01.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
.bgclrpink{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/pink01.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
.bgclrblue{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/blue01.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
.bgclryellow{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/yellow01.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
.bgclryellow2{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/yellow02.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
.bgclrpurple{
	background: url(../img/sbbg/norentp.png), url(../img/sbbg/purple01.jpg);
	background-repeat: repeat-x, repeat;
	background-position: center bottom, center top;
}
@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
}


[class^="cnrimg"]{
	padding: 2em 0;
	min-height: 200px;
}
.cnrimg01{	/**黄花**/
	background: url(../img/sbbg/corner_a_01.svg),
							url(../img/sbbg/corner_a_02.svg),
							url(../img/sbbg/corner_a_03.svg),
	 						url(../img/sbbg/corner_a_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
.cnrimg02{	/**リンゴ**/
	background: url(../img/sbbg/corner_b_01.svg),
							url(../img/sbbg/corner_b_02.svg),
							url(../img/sbbg/corner_b_03.svg),
	 						url(../img/sbbg/corner_b_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
.cnrimg03{	/**赤花**/
	background: url(../img/sbbg/corner_c_01.svg),
							url(../img/sbbg/corner_c_02.svg),
							url(../img/sbbg/corner_c_03.svg),
	 						url(../img/sbbg/corner_c_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
.cnrimg04{	/**家**/
	background: url(../img/sbbg/corner_d_01.svg),
							url(../img/sbbg/corner_d_02.svg),
							url(../img/sbbg/corner_d_03.svg),
	 						url(../img/sbbg/corner_d_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
.cnrimg05{	/**花**/
	background: url(../img/sbbg/corner_e_01.svg),
							url(../img/sbbg/corner_e_02.svg),
							url(../img/sbbg/corner_e_03.svg),
	 						url(../img/sbbg/corner_e_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
.cnrimg06{	/**葉**/
	background: url(../img/sbbg/corner_f_01.svg),
							url(../img/sbbg/corner_f_02.svg),
							url(../img/sbbg/corner_f_03.svg),
	 						url(../img/sbbg/corner_f_04.svg);
	background-position: left 1em top 1em, right 1em top 1em, left 1em bottom 1em, right 1em bottom 1em;
	background-repeat: no-repeat;
	background-size: 60px auto;
}
@media screen and (max-width: 899px) {
	[class^="bgclr"] > div.whtboard{
		width: 88%;
	}
}
@media screen and (min-width: 900px) {
	[class^="bgclr"] > div.whtboard{
		width: 780px;
	}
}


/******************************
TOP
*******************************/
/*****下部TOPICS/*****/
#News{
	padding: 0;
	text-align: center;
}
@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
	#News h2.tpcstit{
		text-align: center;
	}
}

#News ul.Nwslst li a > div > div:last-child{
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
ul.Nwslst {
	width: 100%;
	text-align: left;
	width: 100%;
	padding: 0;
	margin: 1em auto 0;
	list-style: none;
}
ul.Nwslst li{
	line-height: 135%;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}
ul.Nwslst li a{
	color:hsl(0, 0%, 40%);
	text-decoration: none;
	padding: 0;
}
ul.Nwslst li a > div{
	text-align: left;
	width: 100%;
	padding: .5em;
	display: flex;
	transition: .3s all;
}
ul.Nwslst li a:hover > div{
	background: hsla(0, 0%, 0%, .1);
	border-radius: .3em;
}

@media screen and (max-width: 699px) {
	ul.Nwslst {
		text-align: center;
	}
	ul.Nwslst li a > div{
		flex-direction: column;
	}
	ul.Nwslst li a > div > div{
		width: 60%;
		text-align: center;
		margin: auto;
	}
}
@media screen and (min-width: 700px) {
	ul.Nwslst {
		font-size: .9em;
		padding: 0;
	}
	ul.Nwslst li a > div{
		flex-direction: row;
		flex-wrap: wrap;
	}
	ul.Nwslst li a > div > div:first-child{
		width: 120px;
	}
	ul.Nwslst li a > div > div:last-child{
		width: calc(100% - 120px);
	}
}
@media screen and (min-width: 1000px) {
}


/******************************
診療内容 Clinic
*******************************/
dl[class^="clncdtl"]{
	text-align: center;
	margin: auto;
}
dl[class^="clncdtl"] > dt{
	color: hsl(0, 0%, 100%);
	text-align: center;
	font-weight: 500;
	letter-spacing: .1em;
	line-height: 135%;
	padding: .4em 3em;
	margin-bottom: .5em;
	border-radius: 1em;
	display: inline-block;
}
[class^="ctntswth"]{margin: auto;}

dl[class^="clncdtl"] > dd{
	line-height: 150%;
	margin: 1em auto 3em;
}
dl.clncdtlgreen > dt{background: hsl(81, 54%, 60%);}
dl.clncdtlgreen table.opncls td{
	padding: .5em .2em;
}
dl.clncdtlpink > dt{background: hsl(1, 82%, 70%);}
dl.clncdtlpurple > dt{background: hsl(301, 24%, 63%);}
dl.clncdtlyellow > dt{background: hsl(31, 99%, 65%);}
@media screen and (max-width: 899px) {
	dl[class^="clncdtl"] > dd{
		font-size: .9em;
		width: 80%;
	}
	dl[class^="clncdtl"] > dd.clncfl{
		width: 100%;
	}
}
@media screen and (min-width: 900px) {
	dl[class^="clncdtl"] > dd{
		font-size: .8em;
	}
	dl.clncdtlgreen table.opncls{
		width: 50%;
	}
}

/******************************
病院案内 medical
*******************************/
ul.clncgall{
	padding: 0;
	margin: 1em auto;
	list-style: none;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
ul.clncgall li img{
	width: 100%;
}
ul.clncgall li{
	width: calc(100% / 4);
}
dl.dctrdtl{
	padding: 0;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
}
dl.dctrdtl dt{
	text-align: right;
}
dl.dctrdtl dd{
	text-align: left;
}
@media screen and (max-width: 899px) {
	dl.clncdtlgreen > dd > dl.comdtl{
		width: 80%;
		margin: 1em auto;
	}
	dl.dctrdtl{
		margin: 1em auto;
	}
	dl.dctrdtl dt{
		text-align: left;
		width: 60px;
	}
	dl.dctrdtl dd{
		width: calc(100% - 60px);
	}
}
@media screen and (min-width: 900px) {
	.ctntswth60{width: 60%;}
	.ctntswth70{width: 70%;}
	.ctntswth80{width: 80%;}
	dl.clncdtlgreen > dd > dl.comdtl{
		font-size: 1.1em;
		text-align: left;
		width: 65%;
		margin: 1em auto;
	}
	dl.dctrdtl{
		padding: 0 1em;
	}
	dl.dctrdtl dt{
		width: 80px;
	}
	dl.dctrdtl dd{
		width: calc(100% - 100px);
	}
}

/******************************
予防接種 vaccination
*******************************/
.pdfbtn{
	text-align: center;
	margin: .5em auto 3em;
}
.pdfbtn a{
	color: hsl(1, 82%, 70%);
	font-size: 1.2em;
	font-weight: bold;
	line-height: 135%;
	text-decoration: none;
	padding: .3em 30px .3em 45px;
	background:
		url(../img/icon/leaf01.svg) no-repeat left 25px center,
		linear-gradient(#fff, #f8dbf8);
	background-size: 20px, 100% 100%;
	border: 2px solid hsl(0, 0%, 85%);
	border-radius: 2em;
	display: inline-block;
	transition: .3s all;
}
.pdfbtn a:hover{
	background:
		url(../img/icon/leaf01.svg) no-repeat left 25px center,
		linear-gradient(#fff, hsl(300, 67%, 95%));
}
ul.influpdf{
	list-style: none;
	padding: 0;
	margin: 3em auto 1em;
	display: flex;
}
ul.influpdf li{
	padding: 0;
	margin: 0;
}
ul.influpdf li a{
	font-size: 1.1em;
	line-height: 135%;
	text-decoration: none;
	width: 100%;
	height: 100px;
	display: block;
	border-radius: .6em;
	position: relative;
}
ul.influpdf li a::after{
	content: "";
	width: calc(100% - 20px);
	height: 80px;
	background: hsl(0, 0%, 100%);
	border-radius: .5em;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transition: .3s all;
	transform: translateX(-50%) translateY(-50%);
	z-index: 0;
}
ul.influpdf li a:hover::after{
	background: hsla(0, 0%, 100%, .8);
}
ul.influpdf li:last-child a{
	background: url(../img/sbbg/green01.jpg);
}
ul.influpdf li:first-child a{
	background: url(../img/sbbg/yellow01.jpg);
}
ul.influpdf li a img{
	width: 20px;
	position: absolute;
	top: 4px;
	left: 4px;
	z-index: 1;
}
ul.influpdf li a strong{
	white-space: nowrap;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	z-index: 1;
}
ul.influpdf li a span{
	display: block;
}
ul.influpdf li:first-child a span{
	color: hsl(20, 93%, 66%) ;
}
ul.influpdf li:last-child a span{
	color: hsl(120, 56%, 61%);
}

@media screen and (max-width: 899px) {
	ul.influpdf{
		flex-direction: column;
	}
	ul.influpdf li{
		padding: .5em 0;
	}
}
@media screen and (min-width: 900px) {
	ul.influpdf{
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	ul.influpdf li{
		width: calc((100% / 2) - 1em);
	}
}

/******************************
ご予約 Reservation
*******************************/
.rsvbtn{
	text-align: center;
	margin: 1em auto 5em;
}
.rsvbtn a{
	font-size: 1.1em;
	line-height: 135%;
	text-decoration: none;
	padding: 2em 4em;
	border-radius: .6em;
	white-space: nowrap;
	background: url(../img/sbbg/yellow01.jpg);
	display: inline-block;
	position: relative;
	z-index: 1;
}
.rsvbtn a::after{
	content: "";
	width: calc(100% - 20px);
	height: calc(100% - 20px);
	background: hsl(0, 0%, 100%);
	border-radius: .5em;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	transition: .3s all;
}
.rsvbtn a:hover::after{
	background: hsla(0, 0%, 100%, .8);
}
.rsvbtn strong{
	position: relative;
	z-index: 2;
}
.rsvbtn a img{
	width: 20px;
	position: absolute;
	top: 4px;
	left: 4px;
	z-index: 1;
}
ul.reservedtl{
	padding: 0;
	margin: 5em auto;
	display: flex;
	list-style: none;
}
ul.reservedtl li{
	width: 100%;
	text-align: center;
	margin: .5em auto;
}
ul.reservedtl li a{
	color: hsl(0, 0%, 100%);
	font-size: 1.8rem;
	line-height: 135%;
	text-decoration: none;
	padding: .5em 0;
	border-radius: .7em;
	display: block;
	background: hsl(31, 99%, 65%);
	transition: .3s all;
}
ul.reservedtl li a:hover{
	background: hsl(31, 99%, 70%);
}
ul.reservedtl li img{
	vertical-align:middle;
	margin-right: .3em;
}
[class^="btnrsv"]{
	text-align: center;
}
[class^="btnrsv"] a{
	font-size: 1.8rem;
	line-height: 135%;
	text-decoration: none;
	border-radius: .7em;
	display: inline-block;
	box-sizing: border-box;
	transition: .3s all;
}
.btnrsvtop a{
	color: hsl(31, 99%, 65%);
	font-weight: bold;
	padding: .5em 3em;
	background: hsl(51, 100%, 78%);
}
.btnrsvtop a:hover{
	background: hsl(51, 100%, 83%);
}
.btnrsvsub a{
	color: hsl(0, 0%, 100%);
	font-weight: normal;
	padding: .4em 2em .2em 1.5em;
	background: hsl(31, 99%, 65%);
}
.btnrsvsub a:hover{
	background: hsl(31, 99%, 70%);
}
.btnrsvsub img{
	width: 1.8em;
	vertical-align: middle;
	padding-bottom: .3em;
	margin-right: .3em;
}

@media screen and (max-width: 899px) {
	ul.reservedtl{
		width: 80%;
		margin: 3em auto 1em;
		flex-direction: column;
	}
}
@media screen and (min-width: 900px) {
	ul.reservedtl{
		width: 80%;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	ul.reservedtl li{
		text-align: center;
		width: calc(100% / 3 - 1em);
	}
	[class^="btnrsv"] a{
		width: 30%;
	}
}

/****01 登録の前に****/
.rsvtit span{
	color: hsl(0, 0%, 100%);
	font-size: 1.8rem;
	font-weight: normal;
	line-height: 135%;
	text-decoration: none;
	padding: .4em 2em .2em 1.5em;
	border-radius: .7em;
	display: inline-block;
	background: hsl(31, 99%, 65%);
}
.rsvtit img{
	width: 1.8em;
	vertical-align: middle;
	padding-bottom: .3em;
	margin-right: .3em;
}
dl.rsvlst{
	margin: 3em auto;
}
dl.rsvlst dt strong{
	padding: .3em 1em;
	display: inline-block;
	position: relative;
	z-index: 1;
}
dl.rsvlst dt strong::after{
	content: "";
	width: 100%;
	height: 40%;
	background: hsl(50, 100%, 78%);
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: -1;
}
dl.rsvlst dd{
	margin-bottom: 5em;
}
ul.rsvhowto{
	padding: 0;
	margin: 0 auto;
	display: flex;
	list-style: none;
}
ul.rsvhowto li a{
	font-size: .9em;
	text-decoration: none;
	padding: .2em 1em .2em 2em;
	margin: .3em;
	border: 1px solid hsla(0, 0%, 0%, .3);
	border-radius: .3em;
	display: inline-block;
	position: relative;
	transition: .3s all;
}
ul.rsvhowto li a:hover{
	background: hsla(0, 0%, 0%, .1);
}
ul.rsvhowto li a::after{
		content: "";
		border-right: 0 solid transparent;
		border-left: 10px solid hsl(31, 99%, 65%);
		border-top: 5px solid transparent;
		border-bottom: 5px solid transparent;
		position: absolute;
		left: 10px;
		top: 50%;
		transform: translateY(-50%);
}
@media screen and (max-width: 899px) {
	dl.rsvlst{
		font-size: .9em;
		line-height: 135%;
		width: 80%;
	}
	dl.rsvlst dt strong{
		padding: .3em .5em;
	}
	dl.rsvlst dd{
		text-align: left;
	}
	ul.rsvhowto{
		text-align: center;
		flex-direction: column;
	}
}
@media screen and (min-width: 900px) {
	dl.rsvlst{
		font-size: .85em;
		line-height: 135%;
	}
	ul.rsvhowto{
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}
	ul.rsvhowto li{
		margin: 0;
	}
}

/****02 会員登録方法****/
dl.slctitem{
	font-size: .9em;
	line-height: 135%;
}
dl.slctitem dt{
	font-weight: bold;
}
dl.slctitem > dd{
	margin-bottom: 2em;
}
.rsvqrcode{
	text-align: left;
	margin: auto;
	display: flex;
	flex-direction: row;
	align-items: center;
}
.rsvqrcode img{width: 100%; border: 1px solid hsla(0, 0%, 0%, .8);}
.rsvqrcode > div:first-child{
	width: 20%;
}
.rsvqrcode > div:last-child{
	width: 80%;
	padding-left: 2em;
}

@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
	.rsvqrcode{
		width: 50%;
	}
}

/****03 予約方法****/
.apptqrcode{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
}
.apptqrcode >div:first-child{
	font-weight: bold;
	text-align: right;
	padding-right: 3rem;
	position: relative;
}
.apptqrcode >div:first-child::after{
	content: "";
	border-right: 0 solid transparent;
	border-left: 10px solid hsl(31, 99%, 65%);
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
}
.apptqrcode >div:last-child img{
	width: 60px;
	border: 1px solid hsla(0, 0%, 0%, .8);
}

dl.apphope{
	padding: 0 0 1em;
	margin: 3em auto;
	border-bottom: 1px solid hsla(0, 0%, 0%, .8);
}
dl.apphope dt{
	font-weight: bold;
	text-align: center;
	padding: 0;
	margin: 0;
	position: relative;
	z-index: 1;
}
dl.apphope dt::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 1px;
	background: hsla(0, 0%, 0%, .8);
	left: 0;
	top: 50%;
	z-index: -1;
}
dl.apphope dt span{
	padding: .5em 1em;
	background: hsl(0, 0%, 100%);
	display: inline-block;
}
dl.apphope dd{
	text-align: left;
	padding: 0 2em;
	margin: 0;
}
dl.apphope dd > div{
	display: flex;
	align-items: center;
}
dl.apphope dd > div .rsvbtn{
	margin: 0 auto;
}
dl.apphope dd > div > div:first-child{
	padding-right: 2em;
}
@media screen and (max-width: 899px) {
	dl.apphope{
		width: 100%;
	}
	dl.apphope dd{
		padding: 0;
	}
	dl.apphope dd p{
		padding: 0;
		margin: 1em 0;
	}
	dl.apphope dd > div{
		flex-direction: column;
	}
}
@media screen and (min-width: 900px) {
	dl.apphope{
		width: 70%;
	}
}


/****時間予約とは****/
ul.exmanga{
	text-align: center;
	padding: 0;
	margin: 1em auto;
	list-style: none;
	display: flex;
	flex-direction: column;
}
ul.exmanga li{
	width: 30%;
	margin: .3em auto;
	padding: 0;
}
ul.exmanga li img{
	width: 100%;
}


/******************************
よくあるご質問 Q&A
*******************************/
dl.qa-list{
	text-align: left;
	line-height: 150%;
	margin: 1em auto;
}
dl.qa-list > dt{
	font-size: 1.1em;
	line-height: 150%;
	min-height: 35px;
	background: url(../img/icon/question01.svg) no-repeat left center;
	background-size: auto 35px;
	padding: .3em 0 0 3em;
	margin-bottom: 1em;
}
dl.qa-list > dd{
	background: url(../img/icon/answer01.svg) no-repeat left top;
	background-size: auto 35px;
	padding: .3em 0 0 3.5em;
	margin-bottom: 5em;
}
dl.qa-list > dd:last-of-type{
	margin-bottom: 0;
}
dl.mangalst{
	margin: 2em 0 0;
}
dl.mangalst dt{
	text-align: center;
	margin-bottom: .8em;
}
dl.mangalst dt span{
	color: hsl(0, 0%, 100%);
	font-size: 1.2em;
	line-height: 135%;
	padding: .1em 1em;
	background: hsl(40, 99%, 60%);
	border-radius: .3em;
	display: inline-block;
}
dl.mangalst ul{
	padding: 0;
	margin: 0;
	list-style: none;
	display: flex;
}
dl.mangalst ul li{
	padding: 0;
	margin: 0;
	position: relative;
}
dl.mangalst ul li img{width: 100%;}
dl.mangalst ul li:last-child::after{
	display: none;
}

@media screen and (max-width: 899px) {
	dl.qa-list{
		font-size: .9em;
		width: 80%;
	}
	dl.qa-list > dd:nth-of-type(2){
		overflow: hidden;
	}
	dl.qa-list > dd:nth-of-type(2) img{
		width: 150px;
		margin-top: .5em;
		float: right;
	}
	dl.mangalst ul{
		padding: 0 6%;
		flex-direction: column;
	}
	dl.mangalst ul li{
		margin-bottom: 25px;
	}
	dl.mangalst ul li:last-child{
		margin-bottom: 0;
	}
	dl.mangalst ul li::after{
		content: "";
		border-left: 7px solid transparent;
		border-right: 7px solid transparent;
		border-top: 15px solid hsl(40, 99%, 60%);
		border-bottom: 0 solid transparent;
		position: absolute;
		left: 50%;
		bottom: -20px;
		transform: translateX(-50%);
	}
}
@media screen and (min-width: 900px) {
	dl.qa-list{
		font-size: .85em;
		width: 75%;
	}
	dl.qa-list > dd:nth-of-type(2){
		position: relative;
	}
	dl.qa-list > dd:nth-of-type(2) img{
		position: absolute;
		bottom: 0;
		right: -30px;
		width: 150px;
	}
	dl.mangalst ul{
		flex-direction: row;
		justify-content: space-between;
	}
	dl.mangalst ul li{
		width: calc(100% / 3 - 20px);
	}
	dl.mangalst ul li::after{
		content: "";
		border-left: 15px solid hsl(40, 99%, 60%);
		border-right: 0 solid transparent;
		border-top: 7px solid transparent;
		border-bottom: 7px solid transparent;
		position: absolute;
		right: -24px;
		top: 50%;
		transform: translateY(-50%);
	}
}

/******************************
お知らせ index
*******************************/
#Nwsidx{
	text-align: left;
}
#Nwsdtl{
	text-align: left;
}
.l-rowtpcs{
	text-align: left;
	width: 100%;
	margin: auto;
	overflow: hidden;
}
h1.Mncnts{
	line-height: 135%;
	padding: 0 0 1em;
	margin: 2em 0 1em;
	border-bottom: 3px solid hsl(173, 78%, 45%);
}
h1.Mncnts span{
	color: hsl(173, 78%, 45%);
	font-size: .9em;
	line-height: 135%;
	display: block;
}
.imgcntrl{
	font-size: .85em;
	line-height: 150%;
}
.addtoany_content{
	padding-top: 5em;
}
@media screen and (max-width: 899px) {
	.l-rowtpcs{
		text-align: center;
		width: 80%;
		padding: 2em 0;
		flex-direction: column;
	}
	.l-rowtpcs > div:last-child{
		padding-top: 2em;
		margin-top: 2em;
		border-top: 3px dotted hsla(0, 0%, 0%, .3);
	}
}
@media screen and (min-width: 900px) {
	#Nwsdtl{
		padding-left: 20px;
	}
	#Nwsidx ul.Nwslst{
		font-size: .85em;
		line-height: 135%;
		margin: 2em auto;
		padding-left: 1em;
	}
	#Nwsidx ul.Nwslst a > div > div:first-child{
		color: hsl(173, 78%, 45%);
		font-weight: bold;
	}

	.l-rowtpcs{
		padding: 2em 0;
		margin: 5rem auto;
	}
	.l-rowtpcs > div:first-child{
		width: calc(100% - 250px);
		padding: 0 2em;
	}
	.l-rowtpcs > div:last-child{
		width: 250px;
		padding: 0 2em;
		border-left: 3px dotted hsla(0, 0%, 0%, .3);
	}
}
/****ページネーション***/
.pagination{
	color: hsl(0, 0%, 20%);
	font-size: .8em;
	font-weight: bold;
	line-height: 135%;
	padding: 0;
	margin: 3em auto 0;
	display: flex;
	flex-direction: row;
	justify-content: center;
}
.pagination span{
	padding: .5rem;
	margin: .1rem;
	display: inline-block;
}
.pagination a{
	color: hsl(0, 0%, 30%);
	font-weight: normal;
	text-decoration: none;
	padding: .5rem;
	margin: .1rem;
	display: inline-block;
	transition: all 0.5s;
	border-radius: .3em;
}
.pagination a:hover{
	background: hsla(0, 0%, 0%, .1);
}

ul.bfnavi{
	font-size: .8em;
	line-height: 135%;
	width:100%;
	padding:1rem 0;
	margin: 3em auto 0;
	display:flex;
	flex-wrap:wrap;
	justify-content:center;
	flex-direction:row;
	list-style:none;
}
ul.bfnavi li{
	padding: 0 .5rem;
	overflow:hidden;
	white-space:nowrap;
	text-overflow:ellipsis;
}
ul.bfnavi li a{
	color: hsl(0, 0%, 30%);
	text-decoration: none;
	display: inline-block;
	padding: .5rem 1rem;
	border: 1px solid hsl(0, 0%, 70%);
}
ul.bfnavi li a:hover{
	background: hsla(0, 0%, 100%, .1);
}

/****Sidebar*****/
ul.Sdlst{
	padding: 0;
	margin: 0;
	list-style: none;
}
ul.Sdlst li{
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}
ul.Sdlst li select{
	width: 100%;
}
@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
	ul.Sdlst li{
		padding: 0 3rem 0 0;
	}
}
dl.Sdmn{
	font-size: .85em;
	text-align: left;
	padding: 0;
	margin: 0;
}
dl.Sdmn dt{
	color: hsl(173, 78%, 45%);
	font-weight: bold;
	line-height: 135%;
	padding: 0 0 0 17px;
	margin: 0 0 .5em;
	position: relative;
	background: url(../img/icon/flower01.svg?1) no-repeat left top;
	background-size: 15px;
}
dl.Sdmn dd{
	padding: 0 0 0 17px;
	margin: .5em 0 2em;
}
dl.Sdmn ul{
	font-size: .9em;
	line-height: 135%;
	padding: 0;
	margin: 0;
	list-style: none;
}
dl.Sdmn ul li{
	padding: 0;
	margin: 0 0 .5em;
}
dl.Sdmn ul li a{
	text-decoration: none;
	transition: .3s all;
}
dl.Sdmn ul li a:hover{
	text-decoration: underline;
}
dl.Sdmn ul.sdnw li{
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
}
@media screen and (min-width: 1200px) {
}

/******************************
アクセス Access
*******************************/
.aaccsgMAP{
	margin: 1em auto 3em;
	background: hsla(0, 0%, 0%, .3);
}
.aaccsgMAP iframe{
	width: 100%;
	vertical-align: bottom;
}

.accsMAP{
	margin: 1em auto;
	display: flex;
}
.accsMAP img{
	width: 100%;
	border: 2px solid hsl(0, 0%, 80%);
	box-sizing: border-box;
}
.accsMAP > div:first-child{
	z-index: 1;
}
.accsMAP > div:first-child span{
	width: 100%;
	padding: 1em;
	background: hsl(0, 0%, 100%);
	border: 3px solid hsl(1, 82%, 70%);
	border-radius: .6em;
	display: inline-block;
	position: relative;
	box-sizing: border-box;
}

@media screen and (max-width: 899px) {
	.aaccsgMAP{
		margin-top: 3em;
		width: 80%;
	}
	.aaccsgMAP iframe{
		width: 100%;
		height: 300px;
	}
	.accsMAP{
		flex-direction: column;
	}
	.accsMAP > div:first-child{
		margin-bottom: 5px;
	}
	.accsMAP > div:first-child span::before{
		content: "";
		border-left: 30px solid transparent;
		border-right: 0 solid transparent;
		border-top: 100px solid hsl(1, 82%, 70%);
		position: absolute;
		left: 15%;
		bottom: -100px;
		z-index: -1;
	}
}
@media screen and (min-width: 900px) {
	.aaccsgMAP{
		width: 60%;
	}
	.accsMAP{
		width: 70%;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
	.accsMAP > div:first-child{
		width: 35%;
	}
	.accsMAP > div:first-child span::before{
		content: "";
		border-left: 0 solid transparent;
		border-right: 80px solid transparent;
		border-bottom: 30px solid hsl(1, 82%, 70%);
		position: absolute;
		right: -65px;
		top: 40%;
		transform: rotate(10deg);
		z-index: -1;
	}
	.accsMAP > div:last-child{
		width: 60%;
	}
}

/******************************
会社詳細
*******************************/
aside.clinicdtl{
	text-align: center;
	line-height: 150%;
	padding: 1.5em 0 0;
	margin: 0 auto;
}
aside.clinicdtl > img{width: 100%;}

dl.sitmndtl{
	margin: 2em 0;
}
dl.sitmndtl dt{
	margin-bottom: 1em;
}
dl.sitmndtl dd{
	text-align: left;
}
@media screen and (max-width: 899px) {
	aside.clinicdtl{
		padding: 1.5em 0;
	}
	dl.sitmndtl{
		font-size: .9em;
		line-height: 135%;
		padding: 0 10%;
		margin: 2em 0;
	}
	dl.sitmndtl dt img{width: 80%;}
}
@media screen and (min-width: 900px) {
	aside.clinicdtl{
		width: 750px;
	}
	dl.sitmndtl dt img{
		width: 270px;
	}
	.l-rowcmdtl > div:first-child{
		width: 50%;
	}
	.l-rowcmdtl > div:last-child{
		width: 45%;
	}
	.l-rowcmdtl dl.comdtl{
		font-size: .9em;
	}
}

.telgrn{
	color: hsl(81, 55%, 59%);
	font-size: 1.5em;
	line-height: 135%;
	padding-left: .5em;
	margin: .5em 0 .8em;
}
.telgrn a{
	color: hsl(81, 55%, 59%);
	font-size: 1.2em;
	text-decoration: none;
}
.telpink{
	text-align: center;
	color: hsl(1, 82%, 70%);
	font-size: 1.6em;
	line-height: 135%;
	margin: .5em 0 .8em;
}
.telpink a{
	color: hsl(1, 82%, 70%);
	font-size: 1.2em;
	text-decoration: none;
}
dl.comdtl{
	margin: auto;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: baseline;
}
dl.comdtl dt{
	font-size: .8em;
	text-align: center;
	line-height: 100%;
	width: 65px;
	margin-bottom: .5em;
}
dl.comdtl dt span{
	padding: .3em 0;
	border-radius: .5em;
	border: 1px solid hsl(0, 0%, 60%);
	display: block;
}
dl.comdtl dd{
	width: calc(100% - 75px);
	line-height: 135%;
	margin-bottom: .5em;
}
@media screen and (max-width: 899px) {
	.telgrn{
		text-align: center;
		padding-left: 0;
	}
	dl.comdtl dd{
		text-align: left;
	}
}
@media screen and (min-width: 900px) {
	.MNcntr dl.comdtl{
		font-size: .9em;
	}
}

table.opncls{
	font-size: 1.2rem;
	width: 100%;
	margin: 1em auto;
	border-top: 1px solid hsla(0, 0%, 0%, .5);
}
table.opncls tr{
	border-bottom: 1px solid hsla(0, 0%, 0%, .5);
}
table.opncls td{
	padding: .3em .2em;
	white-space: nowrap;
}
table.opncls tr td:first-child{
	text-align: center;
}
ul.sitlkbtn{
	width: 100%;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: row;
	list-style: none;
	justify-content: space-between;
}
ul.sitlkbtn li{
	text-align: center;
	padding: 0;
	margin: 0;
	width: calc(100% / 2 - .7em);
}
ul.sitlkbtn li a{
		color: hsl(0, 0%, 100%);
		line-height: 100%;
		text-decoration: none;
		width: 100%;
		padding: 1.5em 0;
		margin: 2em 0;
		border-radius: .5em;
		background: hsl(81, 55%, 59%);
		display: block;
		transition: .5s all;
}
ul.sitlkbtn li a:hover{background: hsl(81, 55%, 70%);}

@media screen and (max-width: 899px) {
	table.opncls{
		font-size: 1.2rem;
		line-height: 135%;
	}
}
@media screen and (min-width: 900px) {
	table.opncls{
		font-size: 1.4rem;
		line-height: 135%;
	}
}

/******************************
フッター部分
*******************************/
footer#mnft{
	text-align:center;
	margin: 0 auto;
}
.udrmnbg{
	text-align: center;
	padding: 0;
	background: url(../img/tpbg/green01.png) repeat;
	margin-bottom: 1em;
}
.cplt{
	color: hsl(0, 0%, 20%);
	font-size: .65em;
	letter-spacing: .05em;
}

@media screen and (max-width: 899px) {
	footer#mnft{
		padding: 0 0 50px;
		background: url(../img/tpbg/star04.svg) repeat-x center bottom;
	}
	.udrmnbg{
		display: none;
	}
}
@media screen and (min-width: 900px) {
	footer#mnft{
		padding: 0 0 50px;
		background: url(../img/tpbg/star02.png) repeat-x center bottom;
	}
}


#page-top {
	position: fixed;
	padding: 1em 2em;
	z-index: 9999;
	right: 0;
	bottom: 0;
}
#page-top a {
	color: hsl(0, 0%, 100%);
	text-align: center;
	text-decoration: none;
	width: 40px;
	background: hsl(7, 78%, 75%);
	border: 2px solid #fff;
	border-radius: 50%;
	aspect-ratio: 1 / 1;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	transition: .3s all;
}
#page-top a:hover {
	background: hsl(7, 78%, 80%);
}
#page-top img {
	width: 15px;
}

@media screen and (max-width: 899px) {
	#page-top {
		padding: 1em;
	}
}
@media screen and (min-width: 900px) {
}
