/*-------------------------------------------------------------

TOP PAGE

-------------------------------------------------------------*/
/*-------------------------------------------------------------
  top_header_area
-------------------------------------------------------------*/
.top_header_area{
	width: 100%;
/*	background-position:center center;
	background-size:cover; */
	position: relative;
}

/* cover_area ---------------------------------- */
.top_header_area .cover_area{
	width: 100%;
	background-color: #ccc;
	position: relative;
}
.top_header_area .cover_area .cover_box{
	width: 100%;
	background-color: #aaa;
}
.top_header_area .cover_area .cover_box img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* cover_text ------------------------------ */
.top_header_area .cover_area .cover_text{
	width: 100%;
	text-align:right;
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.top_header_area .cover_area .cover_text h2{
	text-align: right;
	font-size: 70px;
	letter-spacing: 5px;
	padding-right: 10%;
	box-sizing: border-box;
}
.top_header_area .cover_area .cover_text h3{
	text-align: right;
	font-size: 30px;
	letter-spacing: 5px;
	padding-right: 10%;
	box-sizing: border-box;
}
/* cover_clinic_txt ------------------------------ */
/* 各店舗のカバー画像用 */
.top_header_area .cover_area .cover_clinic_txt{
	width: 100%;
	text-align:right;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit-transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%);
}
.top_header_area .cover_area .cover_clinic_txt h2{
	text-align: center;
	font-size: 50px;
	letter-spacing: 5px;
	box-sizing: border-box;
}
.top_header_area .cover_area .cover_clinic_txt h2 span{
    background-color: rgba(255,255,255,0.8);
    padding: 10px 20px;
}

/* head_menu_area ------------------------------ */
.top_header_area .head_menu_area{
	width: 100%;
	height: 100px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	position: absolute;
	top:0;
	left: 0;
}
.top_header_area .head_menu_area .head_logo{
	width: 30%;
	height: 100px;
	padding: 15px 0 0 10px;
	box-sizing: border-box;
}
.top_header_area .head_menu_area .head_logo img{
	max-width: 400px;
	height: auto;
}
.top_header_area .head_menu_area .head_menu{
	width: 70%;
	height: 100px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
}
.top_header_area .head_menu_area .head_menu .menu_box{
	width: auto;
	padding: 10px;
	text-align: center;
}
.top_header_area .head_menu_area .head_menu .menu_box a{
	color: #000;
}
.top_header_area .head_menu_area .head_menu .menu_box a:hover{
	color: #083b10;
}
.top_header_area .head_menu_area .head_menu .tel_box{
	width: auto;
	height: 100px;
	padding: 10px 15px;
/*	background-color: rgba(0,130,109,0.8); */
	background-color: rgba(8,59,16,0.8);
	color: #fff;
	position: relative;
}
.top_header_area .head_menu_area .head_menu .tel_box p.tel_txt{
	font-size: 14px;
	text-align: center;
	padding-top: 10px;
}
.top_header_area .head_menu_area .head_menu .tel_box p.telnumber{
	text-align: center;
	color: #fff;
	font-size: 25px;
	font-weight: bold;
}
.top_header_area .head_menu_area .head_menu .tel_box p.telnumber span:before {
	content:"";
	display:inline-block;
	width:25px;
	height:25px;
	margin-right: 5px;
	background:url("../img/common/icon_head_mail.png") no-repeat;
	background-size:contain;
}
.top_header_area .head_menu_area .head_menu .tel_box a{
	position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
}

/* cover_menu_area ------------------------------ */
.cover_menu_area{
	width:1200px;
	position: absolute;
/*	background-color: rgba(0,130,109,0.8); */
	background-color: rgba(8,59,16,0.8);
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	bottom: 10%;
	left: 50%;
	transform: translateX(-50%);
	-webkit- transform: translateX(-50%);
}
.cover_menu_area .cover_menu_box{
	width:20%;
	padding: 20px 10px;
	box-sizing: border-box;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	transition: 0.8s;
	-webkit-transition: 0.8s; /* Chrome、Safari用 */
	-moz-transition: 0.8s; /* Firefox用 */
	-o-transition: 0.8s; /* Opera用 */
	position: relative;
	border-right: 1px dashed #fff;
}
.cover_menu_area .cover_menu_box:last-child {
     border-right:none;
}
.cover_menu_area .cover_menu_box:hover{
	background-color: #083b10;
	color: #fff;
}
.cover_menu_area .cover_menu_box .icon_box{
	width:20%;
	padding-right: 10px;
	box-sizing: border-box;
}
.cover_menu_area .cover_menu_box .icon_box img{
	width:100%;
}
.cover_menu_area .cover_menu_box .txt_box{
	width:auto;
	box-sizing: border-box;
	color: #fff;
}
.cover_menu_area .cover_menu_box a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
}

@media screen and (max-width: 768px) {
	.top_header_area .cover_area{
		height: 400px !important;
	}
	.top_header_area .cover_area .cover_box img {
		height: 400px !important;
	}
	.top_header_area .head_menu_area{
		height: auto;
	}	
	.top_header_area .head_menu_area .head_logo{
		width: 70%;
		height: auto;
		padding: 10px 0 0 5px;
	}
	.top_header_area .head_menu_area .head_logo img{
		max-width: 400px;
		height: auto;
	}
	.top_header_area .head_menu_area .head_menu{
		display: none !important;
	}
	.top_header_area .cover_area .cover_text{
		width: 100%;
		top: 50%;
		left: 0%;
		transform: translateY(-40%);
		-webkit-transform: translateY(-40%);
		-ms-transform: translateY(-40%);
	}
	.top_header_area .cover_area .cover_text h2{
		font-size: 50px;
		letter-spacing: 5px;
		line-height: 60px;
		padding-right: 2%;
	}
	.top_header_area .cover_area .cover_text h3{
		font-size: 18px;
		letter-spacing: 5px;
		padding-right: 2%;
	}
    .top_header_area .cover_area .cover_clinic_txt h2{
        font-size: 30px;
        letter-spacing: 1px;
    }
    .top_header_area .cover_area .cover_clinic_txt h2 span{
        padding: 10px 10px;
    }
	.cover_menu_area{
		position: static;
		width:100%;
		bottom: 0;
		left: 0;
		transform: none;
		-webkit- transform: none;
	}
	.cover_menu_area .cover_menu_box{
		width:50%;
		padding: 15px 10px;
		/* margin: 3px 1%; */
		box-sizing: border-box;
		border-right: none;
        border-bottom: 1px dashed #fff;
		justify-content: flex-start;
	}
	.cover_menu_area .cover_menu_box:nth-child(odd){
		border-right: 1px dashed #fff;
	}
	.cover_menu_area .cover_menu_box:last-child{
		border-bottom: none;
	}
	.cover_menu_area .cover_menu_box .txt_box{
		padding: 0;
		color:#fff;
	}
}

/*-------------------------------------------------------------
  top_greeting_area
-------------------------------------------------------------*/
.top_greeting_area{
	width:100%;
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;

}
.top_greeting_area .greeting_txt{
	width:40%;
	padding: 5%;
}
.top_greeting_area .greeting_txt h3{
	font-weight: bold;
	margin-bottom: 10px;
	font-size: 30px;
}

.top_greeting_area .greeting_txt .link_box{
	width: 80%;
	margin-top: 20px;
	background-color: #083b10;
	border: solid 1px #083b10;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	position: relative;
}
.top_greeting_area .greeting_txt .link_box .link_img{
	width: 50%;
}
.top_greeting_area .greeting_txt .link_box .link_txt{
	width: 50%;
	color: #fff;
	text-align: center;
}
.top_greeting_area .greeting_txt a{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
}
.top_greeting_area .greeting_txt .link_box:hover{
	background-color: #006666;
	border: solid 1px #006666;
}
.top_greeting_area .greeting_img{
	width:60%;
	height: 550px;
}
.top_greeting_area .greeting_img img {
	width: 100%;
	height: 550px;
	object-fit: cover;
}

@media screen and (max-width: 768px) {
	.top_greeting_area .greeting_txt .link_box{
		width: 100%;
	}
	.top_greeting_area .greeting_txt{
		width:100%;
		padding: 10% 3%;
	}
	.top_greeting_area .greeting_txt h3{
		font-size: 20px;
	}
	.top_greeting_area .greeting_txt a{
		width: 70%;
		margin: 10px auto 0 auto;
	}
	.top_greeting_area .greeting_img{
		width:100%;
		height: 300px;
	}
	.top_greeting_area .greeting_img img{
		height: 300px;
	}

}

/*-------------------------------------------------------------
  top_contents_area
-------------------------------------------------------------*/
.top_contents_area{
/*	max-width: 1200px; */
	width: 100%;
/*	padding: 100px 0; */
	padding: 40px 0;
	margin: 0 auto;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}
.top_contents_area .top_contents_box{
	width: 50%;
	padding: 20px;
	margin: 10px 0 20px 0;
}
.top_contents_area h4{
	margin-top: 10px;
	text-align: center;
	font-size: 30px;
	font-weight: normal;
}
.top_contents_area p{
	text-align: center;
	margin-bottom: 5px;
}
.top_contents_area span.free{
	padding: 0 10px;
	color: #083b10;
	display: inline-block;
	background-color: #cfe6e2;
}

@media screen and (max-width: 768px) {
	.top_contents_area{
		max-width: initial;
		width: 96%;
		padding: 50px 0;
	}
	.top_contents_area .top_contents_box{
		width: 100%;
		padding: 0;
		margin: 10px 0 20px 0;
	}
	.top_contents_area h4{
		font-size: 24px;
	}
}

/*-------------------------------------------------------------
  20221117add : top_contact_btn
-------------------------------------------------------------*/
.top_contact_btn{
	width: 100%;
	text-align: center;
	padding: 0 0 40px 0;
	margin: 0 auto;
}
.top_contact_btn a{
	width: 80%;
	max-width: 500px;
	text-align: center;
	display: inline-block;
	padding: 20px;
	background-color: #083b10;
	border: solid 1px #083b10;
	border-radius: 10px;
	color: #fff;
	font-weight: bold;
}
.top_contact_btn a:hover{
	background-color: #006666;
	border: solid 1px #006666;
}

/*-------------------------------------------------------------
  SHOP LIST
-------------------------------------------------------------*/
/* map ------------------------------------ */
.top_map_area{
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin-bottom: 30px;
}
.top_map_area .map_box{
	width: 50%;
	padding: 20px;
	margin: 10px 0 20px 0;
	text-align: center;
}
.top_map_area .map_box h5.area{
	margin: 10px 0;
	text-align: center;
	font-weight: normal;
}
.top_map_area .map_box h5.area span{
	display: inline-block;
	padding-top: 3px;
	padding-bottom: 3px;
	color: #fff;
	border-radius: 10px;
	width: 40%;
}
.top_map_area .map_box img{
	max-width: 100%;
	width: auto;
}
@media screen and (max-width: 768px) {
	.top_map_area .map_box{
		width: 100%;
		padding: 10px;
		margin: 10px 0 10px 0;
	}
	.top_map_area .map_box h5.area span{
		width: 80%;
	}
}

/* shop list ----------------------------- */
.shop_list_area{
	width: 100%;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin: 30px 0;
}
.shop_list_area .shop_box{
	width: 25%;
	padding: 15px;
	margin: 10px 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
}

.shop_list_area .shop_box .shop_imgbox{
	width: 100%;
}
.shop_list_area .shop_box .shop_notebox{
	width: 100%;
}
.shop_list_area .shop_box .shop_name{
	width: 100%;
	margin: 10px 0;
	text-align: center;
	font-weight: bold;
}
.shop_list_area .shop_box .shop_name span.circle{
	display: inline-block;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	text-align:center;
	line-height: 30px;
	margin-right: 10px;
	color:#fff;
}
.shop_list_area .shop_box .shop_more{
	width: 100%;
	margin: 10px 0;
	text-align: center;
}
.shop_list_area .shop_box .shop_more a{
	width: 90%;
	padding-top:5px;
	padding-bottom: 5px;
	display: inline-block;
	border-radius: 10px;
	color: #fff;
	background-color: #083b10;
}
.shop_list_area .shop_box .shop_more a.shoplink{
	background-color: #083b10;
}
.shop_list_area .shop_box .shop_more a.shoplink:hover{
	background-color: #136320;
}
.shop_list_area .shop_box .shop_more a.grouplink{
	background-color: #4e104b;
}
.shop_list_area .shop_box .shop_more a.grouplink:hover{
	background-color: #72286e;
}

@media screen and (max-width: 768px) {
	.shop_list_area .shop_box{
		width: 50%;
		padding: 10px;
	}
}

/*-------------------------------------------------------------
  NEWS & TOPICS
-------------------------------------------------------------*/
.news_area{
/*	width: 100%; */
	width: 90%;
	margin: 30px auto;
	background-color: #fff;
	padding: 30px;
	height: 400px; 
	overflow-y: scroll;
}
.news_area .news_list{
	width: 100%;
	margin-bottom: 10px;
	border-bottom: 1px solid #ddd;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}
.news_area .news_list:last-child{
	border-bottom: none;
}
.news_area .news_list .news_data{
	width: 13%;
}
.news_area .news_list .news_text{
	width: 85%;
	margin-left: 2%;
}
.news_area .news_list .news_text .news_title{
	font-weight: bold;
	margin-bottom: 10px;
}
.news_area .news_list .news_text .news_title a{
	color: #083b10;
}
.news_area .news_list .news_text .news_title a:hover{
    text-decoration: underline;
}

.news_area .news_list .news_text .news_title span.pickup{
	padding: 0 10px;
	margin-right: 5px;
	display: inline-block;
	background-color: #ff8c4d;
	color: #fff;
}
@media screen and (max-width: 768px) {
	.news_area{
		width: 96%;
		margin: 20px auto;
		padding: 15px;
		height: 300px; 
	}
	.news_area .news_list .news_data{
		width: 100%;
		margin-bottom: 15px;
	}
	.news_area .news_list .news_text{
		width: 100%;
		margin-left: 0;
	}
	
}
/* more_news_area ---------------------------------------------- */
.more_news_area{
    width:100%;
    margin: 30px 0;
    text-align: center;
}
.more_news_area a.more_link{
    display: inline-block;
    width:20%;
    padding: 10px 20px;
    color:#fff;
/*	background-color: #06574a; */
	border: solid 1px #fff;
}
.more_news_area a.more_link:hover{
/*	background-color: #7bb2a9; */
background-color:rgba(255,255,255,0.3);
}

@media screen and (max-width: 768px) {
    .more_news_area a.more_link{
        width:80%;
        padding: 10px 10px;
    }
}

/* banner area ---------------------------------------------- */
.banner_area{
	width: 90%;
	margin: 50px auto 0 auto;
	padding-bottom: 60px;
}
.banner_area .banner_slider .bnr_box{
	margin: 0 10px;
}

/*-------------------------------------------------------------
  NOTE
-------------------------------------------------------------*/
.top_note_area{
	width:100%;
	margin: 0;
	padding: 0;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
/* 写真を右側配置にする（デフォルトは左配置） */
.note_right{
	flex-direction: row-reverse !important;
}

.top_note_area .note_photo{
	width: 50%;
	height: 400px;
}
.top_note_area .note_photo img {
	width: 100%;
	height: 400px;
	object-fit: cover;
}
.top_note_area .note_txt{
	width: 50%;
	height: auto;
	padding: 20px 50px;
}
.top_note_area .note_txt h3{
	width: 100%;
	margin-bottom: 20px;
	font-size: 30px;
	font-weight: normal;
}
.top_note_area .note_txt .under {
/*  background: linear-gradient(transparent 50%, #daedea 50%); */
  background: linear-gradient(transparent 50%, #cfe6e2 50%);
}
.top_note_area .note_txt .n_txt_left{
	text-align: left;
}
.top_note_area .note_txt .n_txt_right{
	text-align: right;
}

@media screen and (max-width: 768px) {
	.top_note_area .note_photo{
		width: 100%;
		height: 250px;
	}
	.top_note_area .note_photo img {
		height: 250px;
	}
	.top_note_area .note_txt{
		width: 100%;
		padding: 20px 15px;
	}
	.top_note_area .note_txt h3{
		font-size: 20px;
	}
	.top_note_area .note_txt .n_txt_left,
	.top_note_area .note_txt .n_txt_right{
		text-align: center;
	}
}
