﻿@charset "UTF-8";

/* 初期設定 */
* {

	margin: 0;
	padding: 0;
	box-sizing: border-box;

}

.clearfix:after {

	content: "";
	display: block;
	clear: both;
	
}

img {
	
	width: 100%;
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	border: none;
	
}

li {

	list-style: none;
	
}

a {

	color: #333;
	text-decoration: none;

}

/*

html * {
	
  visibility: hidden;
  
}

html.wf-active * {

  visibility: visible;
  
}

*/

/* HTML */
html {

	min-width: 320px;
	font-size: 62.5%;
	overflow-x: hidden;
	/*-webkit-font-smoothing: antialiased;*/
	
	text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	
}

/* ボディ */
body {

	min-width: 320px;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 18px;
	color: #716864;
	letter-spacing: 0.08em;
	overflow-x: hidden;

}

/* メイン */
main {
	
	display: block;

}

/* 内枠 */
.inner {

	margin: 0 auto;

}

/* ヘッダー */
header {
	
	position: fixed;
	top:  0;
	left: 0;
	z-index: 2;
	width: 100%;
	background: #fff;
	transition: all 0.4s;
	
	padding-top:    3.4rem;
	padding-bottom: 2.4rem;

}

header.active {

	padding-top:    1.0rem;
	padding-bottom: 0.8rem;
	box-shadow: 0 1px 2px 0 rgba(0,0,0, 0.2);

}

header.active_sp {

	box-shadow: 0 1px 2px 0 rgba(0,0,0, 0.2);

}

header .inner {

	width: 95%;

}

/* ロゴ */
header h1 {

	float: left;
	width: 42.8rem;
	margin-top: 1.6rem;
	margin-left: 0.9%;
	line-height: 1;

}

/* 電話 */
header .tel_fax {

	float: right;
	font-family: 'Yusei Magic', sans-serif;

}

header .tel_fax .tel {
	
	white-space: nowrap;
	margin-bottom: 0.35rem;

}

header .tel_fax .fax {
	
	white-space: nowrap;

}

header .tel_fax .title {

	display: inline-block;
	margin-right: 0.8em;
	padding: 0 0.3em 0.1em 0.3em;
	font-size: 2.9rem;
	line-height: 1.15;
	color: #fff;
	letter-spacing: 0.25em;
	background: #683825;

}

header .tel_fax a {

	font-size: 3rem;
	color: #7EBDD9;
	letter-spacing: 0.18em;

}

header .tel_fax .tel a .txt {

	display: inline-block;
	margin-right: 0.9em;

}

header .tel_fax .fax a .txt {

	display: inline-block;
	margin-right: 0.6em;

}

header .tel_fax .fax a .one {

	display: inline-block;
	margin-right: 0.1em;

}

/* メイン画像 */
.mainimg {
	
	position: relative;
	height: 74.2vh;
	margin-bottom: 4rem;
	background-size: cover;
	background-position: center center;

}

.mainimg .en {

	position: absolute;
	top:  10%;
	left: 1.45%;
	width: 4.57rem;

}

.mainimg .txt {
	
	position: absolute;
	right:  0;
	bottom: 0;
	padding-top:    0.8em;
	padding-bottom: 0.9em;
	padding-left:   1.7em;
	padding-right:  9.5em;
	font-family: 'Yusei Magic', sans-serif;
	background: rgba(255,255,255, 0.75);
	box-shadow: 0 0.5em 1em 0.2em rgba(0,0,0, 0.15);

}

.mainimg .txt .line1 {
	
	margin-bottom: 0.4em;
	font-size: 3rem;
	line-height: 1.5;
	letter-spacing: 0.2em;

}

.mainimg .txt .line2 {

	font-size: 4.8rem;
	letter-spacing: 0.2em;

}

/* ナビ */
.navi_main {

	margin-bottom: 18rem;

}

.navi_main ul {
	
	text-align: center;

}

.navi_main ul li {
	
	display: inline-block;
	margin: 0 4.5em;

}

.navi_main ul li a {
	
	position: relative;
	display: inline-block;
	padding-bottom: 0.65em;
	font-family: 'Yusei Magic', sans-serif;
	font-size: 2.4rem;
	color: #716864;
	letter-spacing: 0.2em;

}

.navi_main ul li.on a::after {

	position:absolute;
	left:   2%;
	bottom: 0;
	content: "";
	width:  90%;
	height: 0.19em;
	background: #EF804F;

}

.navi_main ul li a span:hover {

	display: inline-block;
	color: #EF804F;
	transition: all 0.5s;

}

/* セクション */
section .inner {
	
	position: relative;
	float: right;
	width: 89%;

}

/* 見出し */
section h2 {

	float: right;
	width: 89%;
	margin-bottom: 10.5rem;
	padding-top:    0.4em;
	padding-bottom: 0.7em;
	padding-left:   0.5em;
	font-family: 'Yusei Magic', sans-serif;
	font-size: 3.6rem;
	font-weight: 400;
	color: #fff;
	letter-spacing: 0.2em;
	background: #65A4C0;

}

section h2 span {

	color: #FFDD23;

}

/* ご挨拶 */
#greeting {

	margin-bottom: 20rem;

}

#greeting h2 {

	margin-bottom: 10.5rem;

}

#greeting .txt {
	
	width: 75%;

}

#greeting .txt p {
	
	margin-bottom: 2rem;
	font-size: 1.81rem;
	line-height: 2.2;
	letter-spacing: 0.2em;

}

#greeting .appearance {

	position: absolute;
	top:   0.7rem;
	right: 0;
	width: 61rem;

}

/* 診療時間 */
#time {

	margin-bottom: 30rem;

}

#time h2 {

	margin-bottom: 19.5rem;

}

#time .time_img {

	width: 129rem;
	margin-bottom: 4.2rem;

}

#time p {
	
	font-size: 1.8rem;
	line-height: 1.9;
	letter-spacing: 0.2em;

}

/* アクセス */
#access {

	margin-bottom: 16rem;

}

#access h2 {

	margin-bottom: 20rem;

}

#access .map {

	position: relative;
	width:  122rem;
	height: 0;
	margin-bottom: 7.6rem;
	padding-bottom: 26.2%;
	border: 1.5rem solid #AAB3B8;
	overflow: hidden;

}

#access .map iframe {

	position: absolute;
	top:  0;
	left: 0;
	width:  100% !important;
	height: 100% !important;


}

#access .box {

	margin-bottom: 3.6rem;

}

#access .box h3 {
	
	margin-bottom: 0.2rem;
	font-size: 1.8rem;
	font-weight: 500;
	color: #EF804F;

}

#access .box p {
	
	font-size: 1.8rem;
	line-height: 1.8;

}

/* フットロゴ */
.foot {

	padding-top:    4.9rem;
	padding-bottom: 2.4rem;
	border-top: 2px solid #63B1D3;

}

.foot .logo1 {
	
	display: block;
	width: 8.4rem;
	margin: 0 auto;
	margin-bottom: 1.5rem;

}

.foot .logo2 {
	
	display: block;
	width: 34.2rem;
	margin: 0 auto;

}

/* フッター */
footer {
	
	padding-top:    4.7rem;
	padding-bottom: 1.8rem;
	font-size: 1.75rem;
	line-height: 1.8;
	color: #fff;
	letter-spacing: 0.2em;
	background: #63B1D3;

}

footer a {

	color: #fff;

}

footer .inner {
	
	max-width: 148.5rem;
	margin: 0 auto;
	margin-bottom: 6.5rem;

}

footer .left {

	float: left;
	width: 45%;

}

footer .left .tel_fax {

	margin-bottom: 2.5rem;
	font-size: 2rem;
	letter-spacing: 0.22em;

}

footer .left .address dl {

	margin-bottom: 1rem;

}

footer .right {

	float: right;
	width: 54.9%;

}

footer .right .time {
	
	margin-top:    4.5rem;
	margin-bottom: 1.3rem;

}

footer .navi_footer {
	
	margin-bottom: 0.5rem;
	text-align: center;
	font-size: 1.8rem;

}

footer .navi_footer ul li {
	
	position: relative;
	display: inline-block;
	padding: 0 0.6em;

}

footer .navi_footer ul li::after {

	position: absolute;
	top:   25%;
	right: 0;
	content: "";
	width:  1px;
	height: 60%;
	background: #fff;

}

footer .navi_footer ul li:last-child::after {

	width: 0;

}

footer .navi_footer ul li a {

	color: #fff;

}

footer .copy {
	
	display: block;
	text-align: center;
	font-size: 1.8rem;
	letter-spacing: 0.22em;
	
}

.sp_txt {

	display: none;

}

/* ナビ */
.menu {

	display: none;

}

.navi_layer {

	display: none;

}


@media only screen and (max-width: 1600px) {

	/* HTML */
	html {
		
		font-size: 52.0625%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 583px;
		
	}

}



/* 中サイズ */
@media only screen and (max-width: 1366px) {

	/* HTML */
	html {
		
		font-size: 44.4375%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 500px;
		
	}
	
	.mainimg .txt {
		
		padding-top:    0.6em;
		padding-bottom: 0.7em;
		padding-left:   1.2em;
		padding-right:  7em;
		
	}
	
	.navi_main ul li {
		
		margin: 0 3.2em;

	}

}



@media only screen and (max-width: 1240px) {

	/* メイン画像 */
	.mainimg {
		
		height: 452px;
		
	}
	
	/* ナビ */
	.navi_main ul li {
		
		margin: 0 3.5em;
		
	}
	
	/* 内枠 */
	section .inner {
		
		width: 90%;
		
	}
	
	/* 見出し */
	section h2 {
		
		width: 90%;
		
	}
	
	#greeting .txt {
		
		width: 100%;
		margin-bottom: 10rem;
	
	}
	
	#greeting .appearance {
		
		position: static;
		float: right;
		width: 80rem;
		
	}
	
	/* フッター */
	footer .inner {
		
		max-width: 90%;

	}

}



/* iPadPro */
@media only screen and (max-width: 1024px) {

	/* HTML */
	html {
		
		font-size: 33.3125%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 373px;
		
	}
	
	.mainimg .txt {
		
		padding-top:    0.6em;
		padding-bottom: 0.7em;
		padding-left:   1.2em;
		padding-right:  5.5em;
		
	}
	
	/* ナビ */
	.navi_main ul li {
		
		margin: 0 1.8em;
		
	}
	
	.navi_main ul li a {
		
		font-size: 3rem;
	
	}
		
	/* 内枠 */
	section .inner {
		
		width: 89%;
		
	}
	
	/* 見出し */
	section h2 {
		
		width: 89%;
		font-size: 4.2rem;
		
	}
		
	/* ご挨拶 */
	#greeting .txt {
		
		margin-bottom: 10rem;
	
	}
	
	#greeting .txt p {
		
		margin-bottom: 2rem;
		font-size: 2.3rem;
	
	}
	
	#greeting .appearance {
		
		float: right;
		width: 95rem;
		
	}
	
	/* 診療時間 */
	#time {
		
		margin-bottom: 30rem;
		
	}
	
	#time h2 {
		
		margin-bottom: 19.5rem;
		
	}
	
	#time .time_img {
		
		width: 129rem;
		margin-bottom: 4.2rem;
		
	}
	
	#time p {
		
		font-size: 2.3rem;
		line-height: 1.9;
		letter-spacing: 0.2em;
	
	}
	
	
	/* アクセス */
	#access {
		
		margin-bottom: 16rem;
		
	}
	
	#access h2 {
		
		margin-bottom: 20rem;
		
	}

	#access .map {

		width:  122rem;
		margin-bottom: 7.6rem;
		padding-bottom: 26.2%;
		border: 1.5rem solid #AAB3B8;
		
	}
	
	#access .box {
		
		margin-bottom: 3.6rem;
		
	}
	
	#access .box h3 {
		
		margin-bottom: 0.2rem;
		font-size: 2.3rem;
		
	}
	
	#access .box p {
		
		font-size: 2.3rem;
		line-height: 1.8;
		
	}
	
	/* フットロゴ */
	.foot {
		
		padding-top:    4.9rem;
		padding-bottom: 2.4rem;
		border-top: 1px solid #63B1D3;
	
	}
	
	.foot .logo1 {
		
		width: 8.4rem;
		margin-bottom: 1.5rem;
		
	}
	
	.foot .logo2 {
		
		width: 34.2rem;
		
	}
	
	/* フッター */
	footer {
		
		padding-top:    4.7rem;
		padding-bottom: 1.8rem;
		font-size: 2rem;
		line-height: 1.8;
	
	}
	
	footer .inner {
		
		max-width: 148.5rem;
		margin-bottom: 6.5rem;
	
	}

	footer .left {
		
		float: left;
		width: 45%;
		
	}
	
	footer .left .tel_fax {
		
		margin-bottom: 2.5rem;
		font-size: 2.2rem;
	
	}
	
	footer .left .address dl {
		
		margin-bottom: 1rem;
		
	}
	
	footer .right {
		
		float: right;
		width: 54.9%;
		
	}
	
	footer .right .time {
		
		margin-top:    4.5rem;
		margin-bottom: 1.3rem;
		
	}
	
	footer .navi_footer {
		
		margin-bottom: 0.5rem;
		font-size: 2rem;
		
	}
	
	footer .navi_footer ul li {
		
		padding: 0 0.6em;
		
	}
	
	footer .copy {
		
		font-size: 2rem;
		
	}

}



/* AndroidのＬの横 */
@media only screen and (max-width: 854px) {

	/* HTML */
	html {
		
		font-size: 33.3125%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 312px;
		
	}
	
	.mainimg .en {

		top:  6%;
		left: 1.45%;
		width: 4.4rem;

	}
	
	.mainimg .txt {
		
		padding-top:    0.6em;
		padding-bottom: 0.7em;
		padding-left:   1.2em;
		padding-right:  5.5em;
		
	}
	
	/* ナビ */
	.navi_main ul li {
		
		margin: 0 1.8em;
		
	}
	
	.navi_main ul li a {
		
		font-size: 3rem;
	
	}
		
	/* 内枠 */
	section .inner {
		
		width: 89%;
		
	}
	
	/* 見出し */
	section h2 {
		
		width: 89%;
		font-size: 4.2rem;
		
	}
		
	/* ご挨拶 */
	#greeting .txt {
		
		margin-bottom: 10rem;
	
	}
	
	#greeting .txt p {
		
		margin-bottom: 2rem;
		font-size: 2.3rem;
	
	}
	
	#greeting .appearance {
		
		float: right;
		width: 95rem;
		
	}
	
	/* 診療時間 */
	#time {
		
		margin-bottom: 30rem;
		
	}
	
	#time h2 {
		
		margin-bottom: 19.5rem;
		
	}
	
	#time .time_img {
		
		width: 129rem;
		margin-bottom: 4.2rem;
		
	}
	
	#time p {
		
		font-size: 2.3rem;
		line-height: 1.9;
		letter-spacing: 0.2em;
	
	}
	
	
	/* アクセス */
	#access {
		
		margin-bottom: 16rem;
		
	}
	
	#access h2 {
		
		margin-bottom: 20rem;
		
	}

	#access .map {

		width:  122rem;
		margin-bottom: 7.6rem;
		padding-bottom: 26.2%;
		border: 1.5rem solid #AAB3B8;
		
	}
	
	#access .box {
		
		margin-bottom: 3.6rem;
		
	}
	
	#access .box h3 {
		
		margin-bottom: 0.2rem;
		font-size: 2.3rem;
		
	}
	
	#access .box p {
		
		font-size: 2.3rem;
		line-height: 1.8;
		
	}
	
	/* フットロゴ */
	.foot {
		
		padding-top:    4.9rem;
		padding-bottom: 2.4rem;
	
	}
	
	.foot .logo1 {
		
		width: 8.4rem;
		margin-bottom: 1.5rem;
		
	}
	
	.foot .logo2 {
		
		width: 34.2rem;
		
	}
	
	/* フッター */
	footer {
		
		padding-top:    4.7rem;
		padding-bottom: 1.8rem;
		font-size: 2rem;
		line-height: 1.8;
	
	}
	
	footer .inner {
		
		max-width: 88%;
		margin-bottom: 6.5rem;
	
	}
	
	footer .left {
		
		float: left;
		width: 45%;
		
	}
	
	footer .left .tel_fax {
		
		margin-bottom: 2.5rem;
		font-size: 2.2rem;
	
	}
	
	footer .left .address dl {
		
		margin-bottom: 1rem;
		
	}
	
	footer .right {
		
		float: right;
		width: 54.9%;
		
	}
	
	footer .right .time {
		
		margin-top:    4.5rem;
		margin-bottom: 1.3rem;
		
	}
	
	footer .navi_footer {
		
		margin-bottom: 0.5rem;
		font-size: 2rem;
		
	}
	
	footer .navi_footer ul li {
		
		padding: 0 0.6em;
		
	}
	
	footer .copy {
		
		font-size: 2rem;
		
	}

}



/* iPad */
@media only screen and (max-width: 768px) {

	/* メイン画像 */
	.mainimg {
		
		height: 280px;
		
	}
	
	.mainimg .en {

		top:  10%;
		left: 1.45%;
		width: 3.5rem;
		
	}
	
	.mainimg .txt {
		
		padding-top:    0.5em;
		padding-bottom: 0.5em;
		padding-left:   0.8em;
		padding-right:  1.2em;
		
	}
	
	.mainimg .txt .line1 {
		
		margin-bottom: 0.2em;
		font-size: 3rem;
		line-height: 1.5;
		letter-spacing: 0.15em;

	}
	
	.mainimg .txt .line2 {
		
		font-size: 4.6rem;
		letter-spacing: 0.15em;
		
	}
	
	/* ナビ */
	.navi_main ul li {
		
		margin: 0 1.2em;
		
	}
	
	/* ローディング */
	.loading img {
		
		width: 45%;
		
	}

}



/* iPhonePlusの横 */
@media only screen and (max-width: 736px) {



}



/* iPhone8の横 */
@media only screen and (max-width: 667px) {

	/* HTML */
	html {
		
		font-size: 29.5%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 243px;
		
	}
	
	#greeting .appearance {
		
		float: right;
		width: 65%;
		
	}

}



/* iPhone5の横 */
@media only screen and (max-width: 568px) {
	
	/* 改行 */
	.sp_break {
	
		display: none;
	
	}
	
	/* HTML */
	html {
		
		font-size: 27%;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 208px;
		
	}
	
	.mainimg .en {

		top:  10%;
		left: 1.45%;
		width: 3.2rem;
		
	}
	
	.mainimg .txt {
		
		padding-top:    0.5em;
		padding-bottom: 0.5em;
		padding-left:   0.8em;
		padding-right:  1em;
		
	}
	
	.mainimg .txt .line1 {
		
		margin-bottom: 0.2em;
		font-size: 3rem;
		line-height: 1.5;
		letter-spacing: 0.15em;

	}
	
	.mainimg .txt .line2 {
		
		font-size: 4.6rem;
		letter-spacing: 0.15em;
		
	}
	
	/* ナビ */
	.navi_main ul li {
		
		margin: 0 0.5em;
		
	}
	
	.navi_main ul li a {
		
		font-size: 3.5rem;
	
	}
	
	/* ご挨拶 */
	#greeting .txt {
		
		margin-bottom: 10rem;
	
	}
	
	#greeting .txt p {
		
		margin-bottom: 2rem;
		font-size: 2.8rem;
	
	}
	
	#greeting .appearance {
		
		float: right;
		width: 65%;
		
	}
	
	/* 診療時間 */
	#time {
		
		margin-bottom: 30rem;
		
	}
	
	#time h2 {
		
		margin-bottom: 19.5rem;
		
	}
	
	#time .time_img {
		
		width: 129rem;
		margin-bottom: 4.2rem;
		
	}
	
	#time p {
		
		font-size: 2.8rem;
		line-height: 1.9;
		letter-spacing: 0.2em;
	
	}
	
	
	/* アクセス */
	#access {
		
		margin-bottom: 16rem;
		
	}
	
	#access h2 {
		
		margin-bottom: 20rem;
		
	}

	#access .map {

		width: 90%;
		margin-bottom: 7.6rem;
		padding-bottom: 26.2%;
		border: 1.5rem solid #AAB3B8;
		
	}
	
	#access .box {
		
		margin-bottom: 3.6rem;
		
	}
	
	#access .box h3 {
		
		margin-bottom: 0.2rem;
		font-size: 2.8rem;
		
	}
	
	#access .box p {
		
		font-size: 2.8rem;
		line-height: 1.8;
		
	}
	
	/* フットロゴ */
	.foot {
		
		padding-top:    4.9rem;
		padding-bottom: 2.4rem;
		border-top: 1px solid #63B1D3;
	
	}
	
	.foot .logo1 {
		
		width: 8.4rem;
		margin-bottom: 1.5rem;
		
	}
	
	.foot .logo2 {
		
		width: 34.2rem;
		
	}
	
	/* フッター */
	footer {
		
		padding-top:    4.7rem;
		padding-bottom: 1.8rem;
		font-size: 2.5rem;
		line-height: 1.8;
	
	}
	
	footer .inner {
		
		max-width: 90%;
		margin-bottom: 6.5rem;
	
	}

	footer .left {
		
		float: left;
		width: 45%;
		
	}
	
	footer .left .tel_fax {
		
		margin-bottom: 2.5rem;
		font-size: 2.8rem;
	
	}
	
	footer .left .address dl {
		
		margin-bottom: 1rem;
		letter-spacing: 0.1em;
		
	}
	
	footer .right {
		
		float: right;
		width: 54.9%;
		letter-spacing: 0.1em;
		
	}
	
	footer .right .time {
		
		margin-top:    4.5rem;
		margin-bottom: 1.3rem;
		
	}
	
	footer .navi_footer {
		
		margin-bottom: 0.5rem;
		font-size: 2.5rem;
		
	}
	
	footer .navi_footer ul li {
		
		padding: 0 0.6em;
		
	}
	
	footer .copy {
		
		font-size: 2.5rem;
		
	}

}



/* AndLoidL */
@media only screen and (max-width: 480px) {

	/* HTML */
	html {
		
		font-size: 26%;
		
	}
	
	/* ヘッダー */
	header {
		
		padding-top:    0.5rem;
		padding-bottom: 2.5rem;
		
	}
	
	header .inner {
		
		width: 94%;
		
	}
	
	/* ロゴ */
	header h1 {
		
		float: left;
		width: 45rem;
		margin-top:  0;
		margin-left: 0;
		
	}
	
	/* 電話 */
	header .tel_fax {
		
		display: none;
		float: right;
		
	}
	
	header .tel_fax .tel {
		
		margin-bottom: 0;
		
	}
	
	header .tel_fax .fax {
	
		transform: translateY(-0.4em);
	
	}
	
	header .tel_fax .title {
		
		margin-right: 0.2em;
		padding: 0 0.2em 0.1em 0.3em;
		font-size: 2.9rem;
		line-height: 1.15;
		letter-spacing: 0.25em;
		
	}
	
	header .tel_fax a {
		
		font-size: 3rem;
		letter-spacing: 0.16em;
		
	}
	
	header .tel_fax .tel a .txt {
		
		margin-right: 0.9em;
		
	}
	
	header .tel_fax .fax a .txt {
		
		margin-right: 0.6em;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 220px;
		margin-bottom: 45rem;
		
	}
	
	.mainimg .en {

		top:  10%;
		left: 1.45%;
		width: 3.5rem;
		
	}
	
	.mainimg .txt {

		position: absolute;
		right:  0;
		bottom: -27rem;
		width: 100%;
		padding-top:    0.5em;
		padding-bottom: 0.4em;
		padding-left:   1.2em;
		padding-right:  0;
		
	}
	
	.mainimg .txt .line1 {
		
		margin-bottom: 0.4em;
		font-size: 4.2rem;
		line-height: 1.6;
		letter-spacing: 0.22em;

	}
	
	.mainimg .txt .line2 {
		
		font-size: 5.8rem;
		letter-spacing: 0.22em;
		
	}
	
	.sp_txt {
		
		position: absolute;
		right:  3%;
		bottom: 4%;
		display: block;
		font-family: 'Yusei Magic', sans-serif;
		
	}
	
	.sp_txt p {
	
		display: inline-block;
		padding-left: 0.2em;
		padding-bottom: 0.1em;
		font-size: 4.5rem;
		line-height: 1.2;
		color: #fff;
		letter-spacing: 0.25em;
		background: #683825;
	
	}
	
	.sp_txt p.line1 {
	
		margin-bottom: 0.2em;
	
	}
	
	/* ナビ */
	.navi_main {
		
	  opacity: 0;
  	visibility: hidden;
		position: fixed;
		top:  0;
		left: 0;
		z-index: 104;
		width:  100%;
		height: 100vh;
		margin-bottom: 0;
		background: transparent;
		transition: all 0s 0s;
		transition-delay: 0;
		
		display: flex; 
	  flex-direction: column;
	  justify-content: center;
	  align-items: center;
		
	}
	
	.navi_main.active {
	
		opacity: 1;
  	visibility: visible;
  	transition: all 0.6s 0.3s;
	
	}
	
	.navi_main ul li {
		
		display: block;
		margin: 0;
		margin-bottom: 1em;
		
	}
	
	.navi_main ul li.on a::after {

		left:   2%;
		bottom: 10%;
		width:  90%;
		height: 0.14em;
		
	}
	
	.navi_main ul li:last-child {
	
		margin-bottom: 0;
	
	}
	
	.navi_main ul li a {
		
		font-size: 5.5rem;
	
	}
	
	.navi_layer {
		
		display: block;
		position: fixed;
	  top:  calc(50% - 20px);
    left: calc(50% - 20px);
		z-index: 103;
    width:  40px;
    height: 40px;
    background: #fff;
    border-radius: 100%;
		transform: scale(0);
    transition: all 0s;
	
	}
	
	.navi_layer.active {
	
		transform: scale(25);
		transition: all 1.2s;
	
	}
	
	/* 内枠 */
	section .inner {
		
		float: none;
		width: 86%;
		margin: 0 auto;
		
	}
	
	/* 見出し */
	section h2 {
		
		width: 100%;
		padding-left:   1em;
		padding-bottom: 0.5em;
		font-size: 4.4rem;
		
	}
	
	/* ご挨拶 */
	#greeting {
		
		margin-bottom: 25rem;
	
	}
	
	#greeting h2 {
	
		margin-bottom: 10rem;
	
	}
	
	#greeting .txt {
		
		margin-bottom: 12rem;
		padding-right: 0;
	
	}
	
	#greeting .txt p {
		
		margin-bottom: 2rem;
		font-size: 3rem;
		line-height: 1.8;
		letter-spacing: 0.08em;
	
	}
	
	#greeting .txt p .first {
	
		display: inline-block;
		margin-bottom: 2rem;
	
	}
	
	#greeting .appearance {
		
		float: none;
		width: 80%;
		margin-left: 10%;
		
	}
	
	/* 診療時間 */
	#time {
		
		margin-bottom: 23rem;
		
	}
	
	#time h2 {
		
		margin-bottom: 10rem;
		
	}
	
	#time .time_img {
		
		width: 100%;
		margin-bottom: 4.2rem;
		
	}
	
	#time p {
		
		font-size: 3rem;
		line-height: 1.9;
		letter-spacing: 0.08em;
	
	}
	
	/* アクセス */
	#access {
		
		margin-bottom: 18rem;
		
	}
	
	#access h2 {
		
		margin-bottom: 10rem;
		
	}

	#access .map {
		
		float: none;
		width: 100%;
		margin-bottom: 7.6rem;
		padding-bottom: 45%;
		border: 1rem solid #AAB3B8;
		
	}
	
	#access .box {
		
		clear: both;
		margin-bottom: 3.6rem;
		
	}
	
	#access .box h3 {
		
		margin-bottom: 0.2rem;
		font-size: 3rem;
		
	}
	
	#access .box p {
		
		font-size: 3rem;
		line-height: 1.8;
		
	}
	
	/* フットロゴ */
	.foot {
		
		padding-top:    4.5rem;
		padding-bottom: 3.5rem;
	
	}
	
	.foot .logo1 {
		
		width: 8.4rem;
		margin-bottom: 1.5rem;
		
	}
	
	.foot .logo2 {
		
		width: 34.2rem;
		
	}
	
	/* フッター */
	footer {
		
		padding-top:    4.7rem;
		padding-bottom: 1.8rem;
		font-size: 3rem;
		line-height: 1.8;
	
	}
	
	footer .inner {
		
		max-width: 86%;
		margin-bottom: 6.5rem;
	
	}
	
	footer .left {
		
		float: none;
		width: 100%;
		
	}
	
	footer .left .tel_fax {
		
		margin-bottom: 4rem;
		font-size: 3.2rem;
	
	}
	
	footer .left .address dl {
		
		margin-bottom: 3rem;
		letter-spacing: 0.08em;
		
	}
	
	footer .right {
		
		float: none;
		width: 100%;
		letter-spacing: 0.08em;
		
	}
	
	footer .right .time {
		
		margin-top:    4.5rem;
		margin-bottom: 3rem;
		
	}
	
	footer .navi_footer {
		
		margin-bottom: 0.5rem;
		font-size: 3.2rem;
		
	}
	
	footer .navi_footer ul li {
		
		padding: 0 0.6em;
		
	}
	
	footer .copy {
		
		font-size: 2.6rem;
		
	}
	
	/* メニュー */
	.menu {
		
		display: block;
	  position: fixed;
	  top:    6px;
	  right:  20px;
	  z-index: 106;
	  width:  40px;
	  height: 40px;
	  transform: scale(1.1);
		
	}
	
	.menu.active {
		
		top: 4px;
	
	}
	
	.menu__line {
		
		position: absolute;
	  display: block;
	  width:  60%;
	  height: 2px;
	  background: #EF804F;
	  transition: all 0.3s;
	  
	}
	
	.menu__line--top {
		
		top: 10px;
		left: 8px;
	
	}
	
	.menu__line--center {
		
	  top:  18px;
	  right: 8px;
	  
	}
	
	.menu__line--bottom {
		
	  bottom: 11px;
	  left:   8px;
	  
	}
	
	.menu__line--top.active {
	
	  top: 18px;
	  transform: rotate(45deg);
	  
	}
	
	.menu__line--center.active {
		
	  transform: scaleX(0);
	  
	}
	
	.menu__line--bottom.active {
	
	  bottom: 20px;
	  transform: rotate(135deg);
	  
	}

}



/* Iphone12 Pro Max */
@media only screen and (max-width: 428px) {

	/* HTML */
	html {
		
		font-size: 26%;
		
	}
	
	/* ヘッダー */
	header {
		
		padding-top:    0.5rem;
		padding-bottom: 2.2rem;
		
	}
	
	header .inner {
		
		width: 95%;
		
	}
	
	/* ロゴ */
	header h1 {
		
		float: left;
		width: 45rem;
		
	}
	
	/* 電話 */
	header .tel_fax {
		
		float: right;
		
	}
	
	header .tel_fax .tel {
	
		white-space: nowrap;
	
	}
	
	header .tel_fax .fax {
		
		white-space: nowrap;
		transform: translateY(-0.4em);
	
	}
	
	header .tel_fax .title {
		
		margin-right: 0;
		padding: 0 0.1em 0.1em 0.2em;
		font-size: 3rem;
		line-height: 1.15;
		letter-spacing: 0.06em;
		
	}
	
	header .tel_fax a {
		
		font-size: 3.2rem;
		letter-spacing: 0.08em;
		
	}
	
	header .tel_fax .tel a .txt {
		
		margin-right: 0.5em;
		
	}
	
	header .tel_fax .fax a .txt {
		
		margin-right: 0.2em;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 220px;
		margin-bottom: 45rem;
		
	}
	
	.mainimg .en {

		top:  6%;
		left: 1.5%;
		width: 3.8rem;
		
	}
	
	.mainimg .txt {
		
		bottom: -27.5rem;
		padding-top:    0.5em;
		padding-bottom: 0.4em;
		padding-left:   1.2em;
		box-shadow: 0 0.3em 0.5em 0.1em rgba(0,0,0, 0.15);
		
	}
	
	.mainimg .txt .line1 {
		
		font-size: 4rem;

	}
	
	.mainimg .txt .line2 {
		
		font-size: 6.4rem;
		
	}
	
	/* 見出し */
	section h2 {
		
		font-size: 4.6rem;
		
	}
	
	/* ご挨拶 */
	#greeting .txt {
		
		margin-bottom: 10rem;
	
	}
	
	#greeting .txt p {
		
		margin-bottom: 2rem;
		font-size: 3.5rem;
		letter-spacing: 0.08em;
	
	}
	
	/* 診療時間 */
	#time .time_img {
		
		margin-bottom: 4.2rem;
		
	}
	
	#time p {
		
		font-size: 3.4rem;
		line-height: 1.9;
		letter-spacing: 0.08em;
	
	}
	
	/* アクセス */
	#access .map {
		
		margin-bottom: 7.6rem;
		padding-bottom: 45%;
		border: 1rem solid #AAB3B8;
		
	}
	
	#access .box {
		
		clear: both;
		margin-bottom: 3.6rem;
		
	}
	
	#access .box h3 {
		
		margin-bottom: 0.2rem;
		font-size: 3.4rem;
		
	}
	
	#access .box p {
		
		font-size: 3.4rem;
		line-height: 1.8;
		letter-spacing: 0.08em;
		
	}
	
	/* フットロゴ */
	.foot {
		
		padding-top:    4.5rem;
		padding-bottom: 3.5rem;
	
	}
	
	.foot .logo1 {
		
		width: 8.4rem;
		margin-bottom: 1.5rem;
		
	}
	
	.foot .logo2 {
		
		width: 34.2rem;
		
	}
	
	/* フッター */
	footer {
		
		padding-top:    4.7rem;
		padding-bottom: 1.8rem;
		font-size: 3.4rem;
		line-height: 1.8;
	
	}
	
	footer .inner {
		
		margin-bottom: 6.5rem;
	
	}
	
	footer .left {
		
		float: none;
		width: 100%;
		
	}
	
	footer .left .tel_fax {
		
		margin-bottom: 4rem;
		font-size: 3.6rem;
	
	}
	
	footer .left .address dl {
		
		margin-bottom: 3.4rem;
		letter-spacing: 0.08em;
		
	}
	
	footer .right {
		
		float: none;
		width: 100%;
		letter-spacing: 0.08em;
		
	}
	
	footer .right .time {
		
		margin-top:    4.5rem;
		margin-bottom: 3rem;
		
	}
	
	footer .navi_footer {
		
		margin-bottom: 0.5rem;
		font-size: 3.4rem;
		
	}
	
	footer .navi_footer ul li {
		
		padding: 0 0.6em;
		
	}
	
	footer .copy {
		
		font-size: 2.8rem;
		letter-spacing: 0.08em;
		
	}

}



/* iPhonePlus */
@media only screen and (max-width: 414px) {



}



/* iPhone12 Pro */
@media only screen and (max-width: 390px) {

	/* HTML */
	html {
		
		font-size: 24%;
		
	}
	
	.mainimg .en {

		top:  7%;
		left: 1.5%;
		width: 4.1rem;
		
	}

}



/* iPhone8 */
@media only screen and (max-width: 375px) {



}



/* Galaxy */
@media only screen and (max-width: 360px) {
	
	header .tel_fax .title {
		
		padding: 0 0.1em 0.1em 0.2em;
		font-size: 2.9rem;
		letter-spacing: 0.06em;
		
	}
	
	header .tel_fax a {
		
		font-size: 3rem;
		letter-spacing: 0.08em;
		
	}

}



/* iPhone5 */
@media only screen and (max-width: 320px) {

	/* HTML */
	html {
		
		font-size: 22%;
		
	}
	
	/* ヘッダー */
	header {
		
		padding-top: 0;
		
	}
	
	/* ロゴ */
	header h1 {
		
		width: 44rem;
		
	}
	
	header .tel_fax .title {
		
		padding: 0 0.1em 0.1em 0.2em;
		font-size: 2.7rem;
		letter-spacing: 0.06em;
		
	}
	
	header .tel_fax a {
		
		font-size: 2.8rem;
		letter-spacing: 0.1em;
		
	}
	
	/* メイン画像 */
	.mainimg {
		
		height: 180px;
		margin-bottom: 39rem;
		
	}
	
	.mainimg .en {

		top:  10%;
		left: 1.45%;
		width: 3.5rem;
		
	}
	
	.mainimg .txt {
		
		bottom: -24.5rem;
		padding-top:    0.5em;
		padding-bottom: 0.4em;
		padding-left:   1.2em;
		
	}
	
	.mainimg .txt .line1 {
		
		margin-bottom: 0.15em;
		font-size: 3.6rem;

	}
	
	.mainimg .txt .line2 {
		
		font-size: 5.6rem;
		
	}
	
	/* ナビ */
	
	/*
	.navi_main ul li {
		
		margin: 0 0.25em;
		
	}
	
	.navi_main ul li a {
		
		font-size: 3.5rem;
		letter-spacing: 0.1em;
	
	}
	
	*/
	
	footer .copy {
		
		font-size: 2.2rem;
		letter-spacing: 0.08em;
		
	}
	
	/* メニュー */
	.menu {
		
	  top:    5px;
	  right:  20px;
	  width:  40px;
	  height: 40px;
	  transform: scale(1);
		
	}

}