@charset "utf-8";
/* CSS Document */

/* commnparts
-------------------------------------------------- */

main section h2 {
	position: relative;
	padding: 1em 1.6em;
	font-size: 2.4em;
	color: #FFFFFF;
	line-height: 1.5;
	z-index: 11;
}
.cont--bx {
	position: relative;
	padding: 3em 4em;
	background: #eff9f7;
	z-index: 11;
}
.cont--bx h3 {
	margin-bottom: 0.5em;
	font-size: 2em;
	line-height: 1.75;
}
.cont--bx p {
	margin-bottom: 1em;
	font-size: 1.6em;
	line-height: 1.7;
}
.cont--bx .lead {
	font-size: 1.8em;
}
@media (min-width: 769px) {
/* tablet+PC用 */
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
	main section h2 {
		font-size: 2em;
	}
	.cont--bx {
		padding: 3em 2em;
	}
}


/* 
-------------------------------------------------- */
@media (min-width: 769px) {
/* tablet+PC用 */
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
}




/* info--area
-------------------------------------------------- */
.info--area {
	margin-top: 7.2em;
}
.info--area .info--bx {}
.info--area .info--bx h2 {
	padding: 0;
}
.info--area .info--bx h2 span {
	display: inline-block;
	width: 190px;
	padding: 2px 0;
	font-size: 0.8333em;
	text-align: center;
	color: #FFFFFF;
	border-radius: 0 5px 0 0;
}
.info--area .info--01 h2 span { background: #dd68c7;}
.info--area .info--02 h2 span { background: #54bc24;}
.info--bx .info--cont--bx {}
.info--01 .info--cont--bx {
	position: relative;
	padding: 2.1em 2em;
	border: 3px solid #dd68c7;
	background: rgb(255,255,255);
background: -moz-linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(221,104,199,0.2) 100%);
background: -webkit-linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(221,104,199,0.2) 100%);
background: linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(221,104,199,0.2) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff",endColorstr="#dd68c7",GradientType=1);
}
.info--01 .info--cont--bx::before {
	content: '';
	position: absolute;
	top: 1.3em;
	right: 2em;
	width: 116px;
	height: 97px;
	background: url("../img/img_jiko.png") right top no-repeat;
	background-size: 100% auto;
}
.ul--info0101 {
	margin-left: 2em;
}
.ul--info0101 li {
	position: relative;
	margin-bottom: 0.3em;
	font-size: 2.8em;
	font-weight: 700;
}
.ul--info0101 li::before {
	content: '';
	position: absolute;
	left: -0.6em;
	bottom: 0.45em;
	width: 0;
	height: 0;
	border: 3px solid #000;
	border-radius: 4px;
}
.ul--info0101 li small {
	font-size: 0.82142em;
	font-weight: 500;
}
.ul--info0101 li span {
	margin-left: 0.15em;
	font-size: 2.14285em;
	color: #c418ab;
	letter-spacing: 2px;
}
.ul--info0101 li span small {
	font-size: 0.466666666667em;
	font-weight: 700;
}
.ul--info0102 {
	margin-top: 2em;
}
.ul--info0102 li {
	position: relative;
	margin-left: 1em;
	font-size: 1.6em;
	line-height: 1.5;
}
.ul--info0102 li::before {
	content: '・';
	margin-left: -1em;
}

.info--02 .info--cont--bx {
	background: rgb(255,255,255);
background: -moz-linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(140,198,63,0.2) 100%);
background: -webkit-linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(140,198,63,0.2) 100%);
background: linear-gradient(75deg, rgba(255,255,255,0.3) 0%, rgba(140,198,63,0.2) 100%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff",endColorstr="#8cc63f",GradientType=1);
	border: 3px solid #54bc24;
}
.info--02 .info--cont--bx .open--time {
	padding: 0.4em 0 0.4em;
	text-align: center;
	font-size: 2em;
	font-weight: 700;
	color: #ffffff;
	background: #54bc24;
}
.info--02 .info--cont--bx .open--time span {
	margin-left: 1em;
	padding: 0em 1.3em 0.1em;
	font-size: 0.9em;
	color: #000000;
	background: #fff;
	border-radius: 20px;
}

.info--02 .info--cont--bx dl {
	display: flex;
	justify-content: space-between;
	margin: 1.5em 1.4em 1.1em;
}
.info--02 .info--cont--bx dl:first-of-type {
	padding-bottom: 1.2em;
	border-bottom: 1px solid #999999;
}
.info--02 .info--cont--bx dl dt {
	position: relative;
	padding-left: 1em;
	width: 28.5%;
	font-size: 2.8em;
	font-weight: 700;
}
.info--02 .info--cont--bx dl dt::before {
	content: '';
	position: absolute;
	top: 0.5em;
	left: 0;
	transform: translateY(-45%);
	width: 19px;
	height: 19px;
	background: url("../img/icn_arrow_01.svg") left top no-repeat;
	background-size: 100% auto;
}
.info--02 .info--cont--bx dl dt small {
	font-size: 0.82142em;
	font-weight: 500;
}
.info--02 .info--cont--bx dl dd {
	width: 71%;
}
.info--cont--bx .sub {
	margin-top: 0.7em;
	text-align: right;
	font-size: 1.2em;
}
.info--02 .info--cont--bx dl dd .number {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.info--02 .info--cont--bx dd .number .time {
	color: #fff;
	font-weight: 400;
	background: #54bc24;
	border-radius: 3px;
}
.info--02 .info--cont--bx .phone dd .number {
	padding-left: 0.75em;
	font-size: 4.2em;
	font-weight: 700;
}
.info--02 .info--cont--bx .phone dd .number::before {
	content: '';
	position: absolute;
	top: 0.5em;
	left: 0;
	transform: translateY(-50%);
	width: 25px;
	height: 32px;
	background: url("../img/icn_phone.svg") left top no-repeat;
	background-size: 100% auto;
}
.info--02 .info--cont--bx .phone dd .number .time {
	padding: 0.4em 0.7em 0.4em;
	font-size: 0.309em;
	line-height: 1.3;
}

.info--02 .info--cont--bx .line dd .number {
	padding-left: 1em;
	font-size: 3.6em;
	font-weight: 700;
}
.info--02 .info--cont--bx .line dd .number::before {
	content: '';
	position: absolute;
	top: 0.5em;
	left: 0;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	background: url("../img/icn_line.svg") left top no-repeat;
	background-size: 100% auto;
}
.info--02 .info--cont--bx .line dd .number .time {
	padding: 0.182em 1.2em 0.2em;
	font-size: 0.4889em;
	line-height: 1.3;
}
@media (min-width: 769px) {
/* tablet+PC用 */
	.info--area .inner {
		display: flex;
		justify-content: space-between;
	}
	.info--area .info--bx {
		width: 48.3333333333%;
	}
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
	.info--area {
		margin-top: 6.5em;
	}
	.ul--info0101 li { font-size: 2.3em;}
	.info--01 .info--cont--bx::before {
		width: 20%;
		top: 3.2em;
	}
	.info--area .info--bx h2 {
		font-size: 2.4em;
	}
	
	.info--area .info--02 {
		margin-top: 1em;
	}
	.info--02 .info--cont--bx dl {
		display: block;
	}
	.info--02 .info--cont--bx dl dt,
	.info--02 .info--cont--bx dl dd {
		width: 100%;
	}
	.info--02 .info--cont--bx dl dt {
		margin-bottom: 0.5em;
	}
	.info--02 .info--cont--bx .phone dd .number {
		padding-left: 1em;
	}
	.info--02 .info--cont--bx .line dd .number {
		padding-left: 1.3em;
	}
}




/* greeting--area
-------------------------------------------------- */
.greeting--area {
	position: relative;
	overflow: hidden;
}
.greeting--area::before {
	content: '';
	width: 1440px;
	height: 372px;
	position: absolute;
	top:0;
	left: 50%;
	transform: translateX(-840px);
	background: url("../img/bg_ttl_02.png") left top no-repeat;
	background-size: auto 100% ;
}
.greeting--area .cont--bx{
	display: flex;
	justify-content: space-between;
}
.greeting--area .cont--bx .txt {
	width: 69.9%;
}
.greeting--area .cont--bx .photo {
	width: 27.678%;
	margin-bottom: -9.5em;
	transform: translateY(-100px);
}
.greeting--area .cont--bx .img { position: relative;}
.greeting--area .cont--bx .photo .yoshi {
	display: block;
	padding-left: 2.2em;
}
.greeting--area .cont--bx .photo .fuki {
	display: block;
	width: 36.7741%;
	position: absolute;
    top: 29.5%;
}
.greeting--area .cont--bx .photo p {
	margin: 1em 0 0 2.2em;
	font-size: 1.4em;
}
.greeting--area .cont--bx .photo .name {
	text-align: right;
	font-size: 1.6em;
}
@media (min-width: 769px) {
/* tablet+PC用 */
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
	main .greeting--area h2 {
		width: calc(94% - 2em);
		padding: 1em 0.5em;
	}
	.greeting--area::before {
		left: 84%;
	}
	.greeting--area .cont--bx {
		display: block;
	}
	.greeting--area .cont--bx .txt,
	.greeting--area .cont--bx .photo {
		width: 100%;
	}
	.greeting--area .cont--bx .photo {
		margin-bottom: 0;
		transform: translateY(0);
	}
	.greeting--area .cont--bx .photo .img{
		width: 70%;
    margin: 0 auto;
	}
	.greeting--area .cont--bx .photo .fuki {
		width: 39.7741%;
		top: 27%;
		left: -2%;
}
	.greeting--area .cont--bx .photo p {
		margin: 1em 2.2em 0;
	}
}




/* menu--area
-------------------------------------------------- */
.menu--area {
	position: relative;
	overflow: hidden;
}
.menu--area::before {
	content: '';
	width: 1440px;
	height: 140px;
	position: absolute;
	top:0;
	left: 50%;
	transform: translateX(-600px);
	background: url("../img/bg_ttl_01.png") left top no-repeat;
	background-size: auto 100% ;
}
.menu--area .cont--bx::after {
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	top:0;
	left: 0;
	transform: translateX(-600px);
	background: #eff9f7;
	z-index: -1;
}

.menu--area h3 {
	margin-bottom: 1em;
    padding: 0.1em 1em 0.2em;
    border-top: 5px solid #efbde8;
	color: #c418ab;
    background: #fff;
}

.menu--area .cont--bx .lead { margin-bottom: 3em;}

.menu--area table {
	width: 100%;
	margin-bottom: 2em;
	border-top: 1px solid #888888;
	border-left: 1px solid #888888;
}
.menu--area table th,
.menu--area table td {
	padding: 0.5em 1.5em;
	border-right: 1px solid #888888;
	border-bottom: 1px solid #888888;
	font-size: 1.8em;
}
.menu--area table th {
	background: #ffffff;
}
.menu--area table td {}

.menu--att {
	position: relative;
	margin-bottom: 4em;
	padding: 0.3em 0.8em;
	color: #fff;
	background: #54bc24;
}
.menu--att div {	
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 2.2em;
}
.menu--att span {
	margin-left: 1em;
	padding: 0.2em 1em 0.28em;
	font-size: 1.363em;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: #000;
	border-radius: 20px;
	background: #fff;
}
.menu--att::after {
    content: '※実費診療の施術料金が対象です。';
    margin: 0.5em 0 0;
    position: absolute;
    right: 0;
    color: #000;
    text-align: right;
    font-size: 1.3em;
    font-weight: 400;
    line-height: 1.2;
}

.ul--menu01 {
	
}
.ul--menu01 li {
	margin-bottom: 3em;
	padding: 1.2em 2em 0.1em;
	border-top: 5px solid #efbde8;
	background: #fff;
}
.ul--menu01 li h4 {
	margin-bottom: 0.7em;
	font-size: 2.2em;
	line-height: 1.3;
	letter-spacing: 0.05em;
	color: #c418ab;
}
.ul--menu01 li p {}
.ul--menu01 li p img {
	width: 150px;
	float: left;
	margin: 0 20px 5px 0;
}
@media (min-width: 769px) {
/* tablet+PC用 */
	.ul--menu01 {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.ul--menu01 li {
		width: 48.66%;
	}
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
	main .menu--area h2 {
		padding: 1em 0.5em;
	}
	.menu--area h3 {
		padding: 0.5em 1em 0.6em;
		line-height: 1.5;
	}
	.menu--att div {
		display: block;
		padding: 0.6em 0.8em;
		line-height: 1.2;
		text-align: center;
	}
	.menu--att div span {
		display: block;
		margin-left: 0;
		margin-top: 0.6em;
		font-size: 1em;
	}
}




/* 
-------------------------------------------------- */
@media (min-width: 769px) {
/* tablet+PC用 */
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
}




/* 
-------------------------------------------------- */
@media (min-width: 769px) {
/* tablet+PC用 */
}
@media (min-width: 1024px) {
/* PC用 */
}
@media (min-width: 1400px) {
/* PC-wide用 */
}
@media (min-width: 769px) and ( max-width: 1023px) {
/* tablet用 */
}
@media (max-width: 768px) {
/* tablet用 */
}
@media (max-width: 480px) {
/* SP用 */
}
