@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;800&display=swap');

* {
	margin:0px 0px 0px 0px;
	padding:0px 0px 0px 0px;
}
body {
 width: 100%;
 color: #333;
 font-family: "Osaka", "ＭＳ Ｐゴシック", "MS PGOTHIC", Osaka, Verdana, Helvetica, sans-serif;
 font-size: 12px;
 text-align: center;
 line-height: 140%;
 background-image: url(../images/bg.jpg);
 background-position: left top;
 background-size: 20px auto;
 background-repeat: repeat-x;
}
html{ height:100%; }
body{ height:100%; } 

p, ul, li{
	font-size:12px;
}
textarea,input {
	padding:2px;
}
img {
	border: 0px;
}

#head{
	width:100%;
	height:55px;
	background-image: url(../images/logo_bg.jpg);
	background-repeat: repeat-x;
	text-align: center;
}

#main{
	width:900px;
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	padding-bottom: 40px;
}
.title{
	width:900px;
	height:619px;
	margin-right: auto;
	margin-left: auto;
	background-image: url(../images/title.jpg);
	background-repeat: no-repeat;
	text-align: left;
	position: relative;
}
.title a{
	position: absolute;
	left: 51px;
	top: 50px;
 transition: .3s;
}
.title a:hover{
	opacity:0.6;
	filter:alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}
.text{
 margin: 0 auto -60px;
 width: 820px;
 position: relative;
 z-index: 2;
 top: -110px;
}

.prof-box{
	margin: 40px auto 60px;
	width:797px;
}
.prof-box .prof-box1{
	width:490px;
	float: left;
	text-align: justify;
	font-size: 18px;
	line-height: 26px;
}
.prof-box .prof-box1 span{
	font-size: 20px;
}
.prof-box img{
	float: right;
}
.prof-box .prof-box2{
	width:797px;
	font-size: 18px;
	line-height: 26px;
	text-align: justify;
}

.ban{
 margin: 0 auto 25px;
 width: 800px;
 }
.ban a{
 transition: .3s;
 }
.ban a:hover{
 opacity: .5;
}

.bt_waku{
 margin: 30px auto;
 width: 820px;
 background-image: url(../images/bt_waku.jpg);
 background-repeat: no-repeat;
 height: 240px;
 text-align: left;
}
.bt_waku .bt{
	padding-top: 92px;
	padding-left: 218px;
}
.bt_waku .bt a{
	width:384px;
	height: 61px;
 transition: .3s;
}
.bt_waku .bt a:hover {
  opacity:0.6;
  filter: alpha(opacity=60);
}

.pre{
 padding: 102px 0 0 100px;
 width: 820px;
 height: 538px;
 background-image: url(../images/present1.jpg);
 background-position: center top;
 background-repeat: no-repeat;
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 box-sizing: border-box;
}

#campaign{
	width:760px;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	margin-top: 50px;
}


#foot{
	width:100%;
	padding-top: 30px;
	padding-bottom: 80px;
	margin-top: 0px;
	background-color: #f0f0f0;
	margin-right: auto;
	margin-left: auto;
}
.foot-in{
	width:860px;
	margin-right: auto;
	margin-left: auto;
}
#foot .foot-in .left{
	width:460px;
	text-align: left;
}
#foot .foot-in .left a:link,#foot .foot-in .left a:visited,#foot .foot-in .left a:active,#foot .foot-in .left a:hover  {
	color:#333;
	text-decoration: underline;
}
#foot .foot-in .right{
	width:146px;
	text-align: right;
}
#foot .foot-in .right .page_top a{
	width:146px;
	height: 0 !important;
	height /**/: 38px;
	padding-top: 38px;
	display: block;
	overflow:hidden;
	background-image: url(../images/page_top.jpg);
}
#foot .foot-in .right .page_top a:hover { background-position: 0px -38px;}



.info{
	width:670px;
	height: 71px;
	background-image: url(../images/info.jpg);
	background-repeat: no-repeat;
	text-align: left;
	margin-right: auto;
	margin-left: auto;
	margin-top: 20px;
}
.info p{
	font-size: 16px;
	line-height: 20px;
	padding-left: 190px;
	padding-top: 2px;
}
.info p strong{
	color: #333;
}


.shop{
	text-align: left;
	width: 670px;
	margin-right: auto;
	margin-left: auto;
}
.shop .shop_t{
	font-size: 20px;
	font-weight: bold;
	color: #e86801;
	padding-bottom: 15px;
}
.shop .shop_l{
 font-size: 16px;
 line-height: 160%;
 float: left;
 width: 300px;
}
.shop .shop_r{
	font-size: 16px;
 line-height: 160%;
	float: right;
	width: 300px;
}


.tb_area{
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	background-color: #e0f3fc;
	padding-top: 30px;
	padding-bottom: 30px;
}
.tb_area a{
 transition: .3s;
}
.tb_area a:hover {
  opacity:0.6;
  filter: alpha(opacity=60);
}

.book_bg{
 margin: 0 auto 60px;
 width: 820px;
 height: 388px;
 background-image: url(../images/book_bg.jpg);
 position: relative;
}
.book_bg .book1{
 width: 190px;
 height: 279px;
 position: absolute;
 top: 54px;
 left: 192px;
 z-index: 2;
}
.book_bg .book2{
 width: 190px;
 height: 279px;
 position: absolute;
 top: 54px;
 left: 443px;
 z-index: 2;
}
.book_bg a{
 transition: .3s;
}
.book_bg a:hover{
	opacity:0.6;
	filter:alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}

.list{
 margin: 0 auto;
 padding: 30px 0 0;
 width: 800px;
 font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.list .box{
 margin: 0 0 15px;
 width: 100%;
 border-radius: 20px;
 border: 2px solid #387251;
 overflow: hidden;
}
.list .box .boxT{
 padding: 5px 0 10px;
 width: 100%;
 background-color: #387251;
 position: relative;
 cursor: pointer;
}
.list .box .boxT span::before,
.list .box .boxT span::after {
  content: '';
  display: block;
  width: 36px;
  height: 2px;
  background: #fff;
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
}
.list .box .boxT span::after {
  background: #fff;
  transform: translateY(-50%) rotate(90deg);
  transition: 0.5s;
}
.list .box .boxT span.active::after {
  background: #fff;
  transform: rotate(0);
  transition: 0.5s;
}
.list .box .boxT .no{
 float: left;
 margin: 0 0 0 15px;
 padding: 19px 0 0 14px;
 width: 62px;
 height: 70px;
 background-image: url(../images/no.png);
 background-position: left top;
 background-size: 100% auto;
 background-repeat: no-repeat;
 font-size: 24px;
 line-height: 100%;
 text-align: center;
 font-weight: 700;
 color: #387251;
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 box-sizing: border-box;
}
.list .box .boxT .clinic{
 float: left;
 margin: 0 0 0 20px;
 padding: 7px 0 0;
 font-size: 25px;
 line-height: 130%;
 text-align: left;
 font-weight: 500;
 color: #fff;
}
.list .box .boxT .clinic span{
 font-size: 23px;
 font-weight: 400;
 font-feature-settings: "palt";
 display: block;
}
.list .box .in{
 margin: 0 auto;
 padding: 35px 0 20px;
 width: 730px;
 text-align: left;
 display: none;
}
.list .box.active .in{
 display: block;
}
.list .box .in .line{
 margin: 0 0 15px;
 padding: 0 0 16px;
 width: 100%;
 border-bottom: 1px solid #387251;
}
.list .box .in .photo{
 float: left;
 width: 192px;
}
.list .box .in .photo img{
 width: 100%;
 height: auto;
}
.list .box .in .photo .ic{
 padding: 16px 5px 0;
 text-align: center;
}
.list .box .in .photo .ic img{
 float: left;
 width: 86px;
 height: auto;
}
.list .box .in .photo .ic img:nth-child(2n){
 float: right;
}
.list .box .in .photo .ic img:nth-child(3){
 margin: 10px 0 0;
}
.list .box .in .boxR{
 float: right;
 width: 510px;
 color: #231815;
 text-align: left;
}
.list .box .in .boxR .name{
 margin: -4px 0 0;
 font-size: 32px;
 line-height: 120%;
 font-weight: 500;
}
.list .box .in .boxR .name b{
 margin: 0 -5px 0 0;
 padding: 0 0 0 5px;
 font-size: 24px;
 font-feature-settings: "palt";
 display: inline-block;
}
.list .box .in .boxR .name span{
 padding: 0 0 0 22px;
 font-size: 18px;
 line-height: 100%;
 font-weight: 400;
 color: #387251;
 display: inline-block;
}
.list .box .in .boxR .sub{
 padding: 20px 0 0;
 font-size: 18px;
 line-height: 22px;
 font-weight: 500;
}
.list .box .in .boxR p{
 padding: 20px 0 0;
 font-size: 18px;
 line-height: 24px;
 font-weight: 400;
	text-align: justify;
}
.list .box .in .add{
 float: left;
 width: 395px;
 font-size: 18px;
 line-height: 24px;
 font-weight: 400;
}
.list .box .in .boxR2{
 float: right;
 width: 335px;
}
.list .box .in .boxR2 .tel{
 font-size: 40px;
 line-height: 100%;
 font-weight: 700;
}
.list .box .in .boxR2 .tel a{
 padding: 0 0 0 53px;
 color: #231815;
 text-decoration: none;
 display: block;
 background-image: url(../images/tel.jpg);
 background-position: left top 2px;
 background-size: 45px auto;
 background-repeat: no-repeat;
 letter-spacing: 1px;
 transition: .3s;
}
.list .box .in .boxR2 .tel a:hover{
 opacity: .4;
}
.list .box .in .boxR2 .url{
 padding: 10px 0 0;
 font-size: 18px;
 line-height: 100%;
 font-weight: 400;
}
.list .box .in .boxR2 .url a{
 color: #0000cc;
 transition: .3s;
}
.list .box .in .boxR2 .url a:hover{
 opacity: .5;
 text-decoration: none;
}



.left{
	float: left;
}
.right{
	float: right;
}


.mrgn-b20{
	margin-bottom: 20px;
}
.mrgn-b30{
	margin-bottom: 30px;
}
.pad-b30{
	padding-bottom: 30px;
}

.fadein,
.fadein2{
	opacity:0;
}
.fadeup {
	opacity:0;
	transition: .8s;
	transform: translate(0,20px); 
	-webkit-transform: translate(0,20px);
}
.fadeup2 {
	opacity:0;
	transition: .8s;
	transform: translate(0,40px); 
	-webkit-transform: translate(0,40px);
}
.fadeup3 {
	opacity:0;
	transition: 1s;
	transform: translate(0,60px); 
	-webkit-transform: translate(0,60px);
}
.up {
	opacity:1;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}

/* ***********************************************************************
	5 : Clear
*********************************************************************** */

.clearfix:after {
	content   : ".";
	display   : block;
	height    : 0;
	clear     : both;
	visibility: hidden;
}

.clearfix { display: inline-block; }

/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix {
	display: block;
}
/* End hide from IE-mac */
