@charset "UTF-8";

body {
	margin: 0 auto;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	line-height: 32px;
}
@media only screen and (max-width: 768px) {
	body {
		font-size: 14px;
		line-height: 28px;
	}
}
a {
	text-decoration:none;
	color: #236045;
}
a:hover {
  opacity: 0.5;
  transition-duration: 0.5s;
}
a:hover img{
  opacity: 0.5;
  transition-duration: 0.5s;
}
li {
	list-style:none;
}
.red {
	color:#FF0000 !important;
}
.blu {
	color:#6bbcf3;
}
h1,h2,h3,h4,h5{
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #236045;
}
h1 {
	font-size: 2.5vw;
	line-height: 4.0vw;
}
h2 {
	font-size: 1.8vw;
}
h3 {
	font-size: 1.6vw;
}
h4 {
	font-size: 1.6vw;
	text-align: center;
}
@media only screen and (max-width: 768px) {
	h1 {
		font-size: 26px;
		line-height: 32px;
	}
	h2 {
		font-size: 26px;
	}
	h3 {
		font-size: 24px;
	}
	h4 {
		font-size: 24px;
	}
}
.sp_br {
	display: none;
}
@media only screen and (max-width: 768px) {
	.sp_br {
		display: block
	}
	.pc_br {
		display: none;
	}
}
#header-area {
	margin: 0;
	padding: 0;
	position: relative;
}
.top-key {
	background-image: url("../img/top_key.png");
	background-size: 100%;
	background-repeat: no-repeat;
	height: 55vw;
}
@media only screen and (max-width: 768px) {
	.top-key {
		background-image: url("../img/top_key_sp.png");
		height: 127vw;
	}
}
.h1_area {
	position: absolute;
	top:  56%;
	left: 53%;
	width: 31%;
}
@media only screen and (max-width: 768px) {
	.h1_area {
		top: 62%;
		left: 26%;
		width: 68%;
	}
}
.cont-h1_area {
	position: absolute;
	top: 25%;
    left: 15%;
	width: 31%;
}
@media only screen and (max-width: 768px) {
	.cont-h1_area {
		top: 3%;
        left: 7%;
		width: 68%;
	}
}
.cont-h1_area h1 {
	color: #fff;
}
.header-menu {
	position: absolute;
	width: 84%;
	background: #fff;
	height: 70px;
	top:5%;
	left: 8%;
	border-radius: 10px;
	display: flex;
}
@media only screen and (max-width: 768px) {
	.header-menu {
		width: 100%;
		top:0;
		left:0;
		border-radius: 0px;
		height: 50px;
	}
}
.cont-header-menu {
	width: 100%;
	background: #fff;
	height: 70px;
	top:5%;
	left: 8%;
	border-radius: 10px;
	display: flex;
}
@media only screen and (max-width: 768px) {
	.cont-header-menu {
		width: 100%;
		top:0;
		left:0;
		border-radius: 0px;
		height: 50px;
	}
}
.logo {
	width: 20%;
}
.logo img{
	padding-top: 23px;
	padding-left: 55px;
}
@media only screen and (max-width: 768px) {
	.logo img{
		padding-top: 13px;
		padding-left: 14px;
	}
}
.global-menu {
	position: absolute;
	right: 0;
	width: 75%;
	top: 6%;
}
@media screen and (max-width: 767px){
	.global-menu {
		display: none;
	}
}
.global-menu ul {
	display: flex;
	justify-content: flex-end;
}
.global-menu li {
	color: #236045;
	font-size: 15px;
	margin-right: 5%;
}
@media screen and (max-width: 1350px){
	.global-menu li {
		font-size: 1vw;
	}
}
@media screen and (max-width: 767px){
	.global-menu li {
		font-size: 1vw;
	}
}
.cont-global-menu {
	position: absolute;
	right: 0;
	width: 75%;
}
@media screen and (max-width: 767px){
	.cont-global-menu {
		display: none;
	}
}
.cont-global-menu ul {
	display: flex;
	justify-content: flex-end;
}
.cont-global-menu li {
	color: #236045;
	font-size: 15px;
	margin-right: 4%;
}
@media screen and (max-width: 1350px){
	.cont-global-menu li {
		font-size: 1.1vw;
	}
}
@media screen and (max-width: 767px){
	.cont-global-menu li {
		font-size: 1vw;
	}
}
#main-top p{
	color: #236045;	
}
/** ニュース **/
#news {
	display: flex;
	background-image: url("../img/h2_box_bk_l.png");
	background-repeat: no-repeat;
	padding: 3.5% 8%;
	margin-top: 5%;
}
@media screen and (max-width: 767px){
	#news {
		display: block;
		padding: 3.5% 4%;
		margin-top: 38px;
		background-image: url("../img/news_l_sp.png");
		background-size: 100%;
		margin-bottom: 8%;
	}
}
.h2_box {
	width: 20%;
	padding-top: 9%;
	padding-left: 5%;
	background-image: url("../img/news-h2_bk.png");
	background-repeat: no-repeat;
	background-size: 25%;
	background-position: top 28% left 31%;
}
@media screen and (max-width: 767px){
	.h2_box {
		width: 100%;
		text-align: center;
		padding: 5px 0;
		margin-bottom: 5%;
		background-position: top 3px left 48%;
		background-size: 20%;
	}
}
.h2_box h2 {
	margin-top: 0;
	margin-bottom: 0;
}
@media screen and (max-width: 767px){
	.h2_box h2 {
		padding-top: 40px;
	}
}
.news_box {
	background-image: url("../img/nwes_bk.png");
	background-repeat: no-repeat;
	background-size: 30%;
	background-position: top 45% right 2%;
	background-color: #fff;
	width: 70%;
	padding: 3% 0;
}
@media screen and (max-width: 767px){
	.news_box {
		width: 100%;
		padding: 0 0 8% 0 ;
		background-size: 71%;
		background-position: top 89% right 2%;
	}
}
.news-list{
  list-style: none outside;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 767px){
	.news-list{
		padding: 0 5%;
	}
}
.news-list .item a{
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  color: #333;
}
.news-list .item {
	display: flex;
	border-bottom: 1px solid #CCC;
  padding: 20px 20px;	
}

.news-list .item:first-child {
  border-top: 1px solid #CCC;
}
.news-list .item .date{
  margin: 0;
  min-width: 120px;
  font-size: 16px;
  color: #999;
  padding: 0 20px 0 0;
}
.news-list .item .title{
  margin: 0;
  width: 100%;
}
.news-list .item a:hover .title{
  color: #00F;
}

@media screen and (max-width: 767px){
	.news-list .item {
		flex-wrap: wrap;
		padding: 12px 0px;
	}
	.news-list .item a{
		flex-wrap: wrap;
		padding: 12px 0px;
	}
	.news-list .item .date{
		min-width: 100px;
	}
	.news-list .item .title{
		margin-top: 0px;
	}
}
#business-top {
	background-image: url("../img/top_bus_bk.png");
	background-repeat: no-repeat;
	background-size: 100%;
	padding-bottom: 10%;
}
@media screen and (max-width: 767px){
	#business-top {
		background-image: url("../img/cont_bk_sp.png");
	}
}
.business-h2 {
	width: 30%;
	margin: auto;
	text-align: center;
	background-image: url("../img/busi-h2_bk.png");
	background-repeat: no-repeat;
	background-size: 75%;
	background-position: top 0 left 50%;
	padding: 3% 0;
	margin-bottom: 9%;
}
@media only screen and (max-width: 768px) {
	.business-h2 {
		width: 78%;
	}
}
.top-cont-box {
	display: flex;
	width: 80%;
	margin-bottom: 9%;
}

@media only screen and (max-width: 768px) {
	.top-cont-box {
		display: block;
		width: 100%;
		margin-bottom: 20%;
	}
}
.top_c-text {
	width: 35%;
	margin-right: 15%;
	position: relative;
}
@media only screen and (max-width: 768px) {
	.top_c-text {
		width: 90%;
		margin: auto;
	}
}
.top-btn {
	position: absolute;
	bottom: 25%;
	width: 100%;
	border-radius: 10px;
	border: 1px solid ;
	color: #236045;
	text-align: center;
}
@media only screen and (max-width: 768px) {
	.top-btn {
		position: static;
		margin-top: 45px;
	}
}
.top-btn a{
	display: block;
	padding: 8px 0;
	border-radius: 10px;
}
.top-btn a:hover {
	opacity: 1;
	transition-duration: 0.5s;
	background-color:  #236045;
	color: #fff;
}
.top_c-img {
	width: 50%;
}
@media only screen and (max-width: 768px) {
	.top_c-img {
		width: 90%;
		margin-left: 10%;
	}
}
.top_c-img img {
	width: 100%;
}
.box-l {
	margin-left: 20%;
}
.box-l div:first-child {
	order: 2;
}
@media only screen and (max-width: 768px) {
	.box-l {
		margin-left: 0%;
	}
}
.box-r .top_c-text {
	margin-left: 15%;	
	margin-right: 0;
}
@media only screen and (max-width: 768px) {
	.box-r .top_c-text {
		margin-left: 0;	
		margin: auto;
	}
	.box-r .top_c-img {
		margin-left: 0;
	}
}
#other-top {
	display: flex;
	width: 80%;
	margin: auto;
	justify-content: space-around;
}
@media only screen and (max-width: 768px) {
	#other-top {
		display: block;
	}
}
.other-box {
	position: relative;
	width: 35%;
	background-color: #e6f4f8;
	height: 22vw;
	padding: 0 5%;
}
@media only screen and (max-width: 768px) {
	.other-box {
		width: 90%;
		height: 200px;
		padding: 0 6%;
	}
}
.other-box h4 {
	padding-top: 4.5%;
	background-image: url("../img/top_h4.png");
	background-repeat: no-repeat;
	background-position: top 0 left 50%;
	background-size: 1.8%;
}
@media only screen and (max-width: 768px) {
	.other-box h4 {
		background-position: top 30% left 50%;
		background-size: 2.5%;
		padding-top: 30px;
	}
}
.about-img {
	background-image: url("../img/about_img.png");
	background-repeat: no-repeat;
	background-position: bottom 0 left 13%;
	background-size: 25%;
}
@media only screen and (max-width: 768px) {
	.about-img {
		background-size: 25%;
	}
}
.staff-img {
	background-image: url("../img/staff.png");
	background-repeat: no-repeat;
	background-position: bottom 0 left 13%;
	background-size: 30%;
}
@media only screen and (max-width: 768px) {
	.staff-img {
		background-size: 30%;
	}
}
.other-btn {
	position: absolute;
	bottom: 7%;
	width: 40%;
	border-radius: 10px;
	border: 1px solid ;
	color: #236045;
	text-align: center;
	margin-left: 35%;
}
@media only screen and (max-width: 768px) {
	.other-btn {
		margin-top: 45px;
		bottom: 7%;
		width: 48%;
		margin-left: 40%;
	}
}
.other-btn a{
	display: block;
	padding: 8px 0;
	border-radius: 10px;
	font-size: 0.8vw;
}
@media only screen and (max-width: 768px) {
	.other-btn a{
		font-size: 11px;
		padding: 3px 0;
	}
}
.other-btn a:hover {
	opacity: 1;
	transition-duration: 0.5s;
	background-color:  #236045;
	color: #fff;
}
#map-area {
	text-align: center;
	margin-top: 8%;
}
/* Google Mapを囲う要素 */
.map-wrap {
	max-width: 100%; /* ここに横幅を指定 */
	margin: auto;
	margin-top: 4%;
}
.map {
    height: 13vw;
    overflow: hidden;
    padding-bottom: 30%;
    position: relative;
}

/* Google Mapのiframe */
.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 768px) {
	.map-wrap {
		max-width: 100%;
		height: 80vw;
	}
	.map {
		height: 60vw;
	}
}
.map-h2 {
	width: 30%;
	margin: auto;
	text-align: center;
	background-image: url("../img/map-h2_bk.png");
	background-repeat: no-repeat;
	background-size: 75%;
	background-position: top 0 left 50%;
	padding: 3% 0 3% 0;
}
@media only screen and (max-width: 768px) {
	.map-h2 {
		width: 78%;
	}
}
#bana-top {
	background-color: #f0e6d9;
	padding-top: 6%;
}
@media only screen and (max-width: 768px) {
	#bana-top {
		padding-top: 16%;
		padding-bottom: 1%;
	}
}
#bana-top h5 {
	font-size: 3vw;
	text-align: center;
	margin: 4% 0 30% 0;
}
@media only screen and (max-width: 768px) {
	#bana-top h5 {
		font-size: 40px;
		margin: 4% 0 3% 0;
	}
}
.bana-area {
	width: 80%;
	margin: auto;
	display: flex;
	justify-content: space-around;
}
@media only screen and (max-width: 768px) {
	.bana-area {
		display: block;
		width: 86%;
	}
}
.bana-box {
	width: 23%;
	background-color: #fff;
	padding: 5% 3% 8% 3%;
	border-radius: 15px;
	position: relative;
}
@media only screen and (max-width: 768px) {
	.bana-box {
		width: 88%;
		padding: 5% 6% 8% 6%;
		margin-bottom: 10%;
		border-radius: 5px;
	}
}
.bana-logo {
	width: 45%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.bana-logo {
		margin-right: 5%;
		width: 47%;
	}
	
}
.bana-logo img {
	width: 100%;
}
.bana-text {
	width: 68%;
	margin: auto;
}
@media only screen and (max-width: 1450px) {
	.bana-text {
		width: 78%;
	}
}
@media only screen and (max-width: 768px) {
	.bana-text {
		width: 100%;
	}
}
.bana-text p {
	font-size: 21px;
	line-height: 26px;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #236045;
}
@media only screen and (max-width: 1600px) {
	.bana-text p {
		font-size: 16px;
	}
}
@media only screen and (max-width: 1275px) {
	.bana-text p {
		font-size: 14px;
	}
}
.bana-btn {
	position: absolute;
	bottom: 5%;
	width: 80%;
	border-radius: 10px;
	border: 1px solid ;
	text-align: center;
	color: #fff;
}
@media only screen and (max-width: 768px) {
	.bana-btn {
		position: static;
		margin-top: 45px;
		width: 90%;
		margin: auto;
	}
}
.bana-btn a{
	display: block;
	padding: 8px 0;
	color: #fff;
}
@media only screen and (max-width: 768px) {
	.bana-btn a{
		border-radius: 5px;
	}
}
.bana-btn a:hover {
	opacity: 0.5;
	transition-duration: 0.5s;
	background-color:  #fff;
	color: #999;
}
.font_free {
	font-size: 18px;
}
@media only screen and (max-width: 1600px) {
	.font_free {
		font-size: 16px;
	}
}
@media only screen and (max-width: 1480px) {
	.font_free {
		font-size: 14px;
	}
}
.green_btn {
	background-color:  #236045;
	
}
.purple_btn {
	background-color:  #980099;
	
}
.dark_purple_btn {
	background-color:  #4c2b67;
}
@media only screen and (max-width: 768px) {
	.sp_bana_box {
		display: flex;
	}
	.bana-text-sp {
		width: 65%;
	}
}
#footer-top {
	background-color: #f0e6d9;
	padding-top: 3%;
	padding-bottom: 3%;
	text-align: center;
}
#footer-top  p {
	color: #9f9f9f;
	font-size: 12px;
}
.drawer--right .drawer-hamburger, .drawer--right.drawer-open .drawer-nav, .drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
	display: none;
}
@media only screen and (max-width: 768px) {
	.drawer--right .drawer-hamburger, .drawer--right.drawer-open .drawer-nav, .drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
	display: block;
	}
}
.cont-key {
	background-size: 100%;
	background-repeat: no-repeat;
	height: 32vw;
}
@media only screen and (max-width: 768px) {
	.cont-key {
		height: 75vw;
	}
}
.company-key {
	background-image: url("../img/company_h1.png");
}
@media only screen and (max-width: 768px) {
	.company-key {
		background-image: url("../img/company_h1_sp.png");
	}
}
.staff-key {
	background-image: url("../img/satff_h1.png");
}
@media only screen and (max-width: 768px) {
	.staff-key {
		background-image: url("../img/satff_h1_sp.png");
	}
}
.inquiry-key {
	background-image: url("../img/inquiry-key.png");
}
@media only screen and (max-width: 768px) {
	.inquiry-key {
		background-image: url("../img/inquiry-key_sp.png");
	}
}
.pp-key {
	background-image: url("../img/pp-key.png");
}
@media only screen and (max-width: 768px) {
	.pp-key {
		background-image: url("../img/pp-key_sp.png");
	}
}
#cont_main {
	width: 80%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	#cont_main {
		width: 100%;
	}
}
#cont_main h2 {
	background-image: url("../img/cont-h2.png");
	background-repeat: no-repeat;
	padding:  35px 0px 15px 70px;
	font-size: 28px;
	line-height: 36px;
}
@media only screen and (max-width: 768px) {
	#cont_main h2 {
		background-size: 10%;
		padding: 25px 0px 15px 43px;
	}
}
.cont_area {
	margin-bottom: 4%;
}
@media only screen and (max-width: 768px) {
	.cont_area {
		width: 86%;
		margin: auto;
	}
}
.staff-box {
	display: flex;
	width: 76%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.staff-box {
		display: block;
		width: 100%;
	}
}
.staff-box-img {
	width: 50%;
}
@media only screen and (max-width: 768px) {
	.staff-box-img {
		width: 100%;
	}
}
.staff-box-img img {
	width: 100%;
	
}
@media only screen and (max-width: 768px) {
	.staff-box-img img {
		width: 90%;
		margin-left: 10%;
	}
}
.staff-box-text {
	width: 45%;
	margin-left: 5%;
}
@media only screen and (max-width: 768px) {
	.staff-box-text {
		width: 84%;
		margin: auto;
	}
}
.staff-box-sub {
	width: 76%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.staff-box-sub {
		width: 84%;
	}
}
.comment-staff {
	width: 51%;
	margin: auto;
	margin-top: 4%;
	margin-bottom: 4%;
	border: #236045 solid 1px;
	border-radius: 10px;
	background-image: url("../img/staff_subimg_sp.png");
	background-repeat: no-repeat;
	background-size: 17%;
    background-position: top 50% left 7%;
	padding: 1% 2% 1% 23%;
}
@media only screen and (max-width: 768px) {
	.comment-staff {
		width: 76%;
        background-position: top 13% left 45%;
        padding: 49% 4% 3% 4%;
        background-size: 63%;
	}
}
.staff-area {
	margin-bottom: 12%;
}
@media only screen and (max-width: 768px) {
	.staff-area {
		margin-bottom: 100px;
	}
}
.group_table {
	margin-bottom: 10%;
}
.group_table table{
  border-collapse: collapse;
  width: 100%;
}
.tb01 th,
.tb01 td{
  padding: 20px 25px 20px 35px;
  border: solid 1px #ccc;
  box-sizing:border-box;
	text-align: left;
	color: #236045;
}
.tb01 th {
	background: #236045;
	color: #fff;
	width: 25%;
}
.tb01 td p {
	margin-top: 0;
}
@media screen and (max-width: 640px) {
  .tb01 {
    width: 100%;
  }
  table.tb01 th,
  table.tb01 td {
    display: block;
    width: 100%;
    border-bottom:none;
	 padding: 10px 15px 10px 15px;
  }
  .tb01 tr:last-child{
    border-bottom: solid 1px #ccc;
  }
}
.clinic-key {
	background-size: 100%;
	background-repeat: no-repeat;
	height: 35vw;
}
@media only screen and (max-width: 768px) {
	.clinic-key {
		height: 129vw;
	}
}
.kirin-key {
	background-image: url("../img/kirin_key.jpg");
}
@media only screen and (max-width: 768px) {
	.kirin-key {
		background-image: url("../img/kirin_key_sp.jpg");
	}
}
.clinic-h1 {
	position: absolute;
	top: 41%;
    left: 25%;
	width: 31%;
}
@media only screen and (max-width: 768px) {
	.clinic-h1 {
		top: 9%;
        left: 47%;
        width: 50%;
	}
}
.clinic-h1 h1 {
	color: #236045;
	font-size: 2.1vw;
    line-height: 4.0vw;
}
@media only screen and (max-width: 768px) {
	.clinic-h1 h1 {
		color: #fff;
		font-size: 20px;
		line-height: 48px;
	}	
}
.kirin-moji {
	font-size: 3vw;
	padding-left: 15%;
}
@media only screen and (max-width: 768px) {
	.kirin-moji {
		font-size: 40px;
		padding-left: 18%;
	}
}
.clinic-cont {
	width: 84%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.clinic-cont {
		width: 100%;
	}
}
.clinic-cont h2 {
	margin-bottom: 5%;
}
@media only screen and (max-width: 768px) {
	.clinic-cont h2 {
		width: 84%;
		margin-left: 3%;
		background-color: #236045;
		padding: 3% 5% 4% 8%;
		border-radius: 35px 0 0 35px;
		background-image: url("../img/ten.png");
		background-repeat: no-repeat;
		background-position: left 3% top 50% ;
		font-size: 22px;
		background-size: 8px;
		margin-top: 15%;
	}
}
.h2-bk {
	background: url("../img/ten.png") right 5% bottom 50% no-repeat, url("../img/ten.png") left 5% top 50% no-repeat;
	background-color: #236045;
	color: #fff;
	padding: 0.7% 5%;
	border-radius: 35px;
	background-size: 10px;
}
@media only screen and (max-width: 768px) {
	.h2-bk {
		padding: 0%;
		border-radius: 0;
		background: none;
	}
}
.clinic-cont-box {
	width: 84%;
	margin: auto;
}
.clinic-text-top {
	margin-top: 4%;
	margin-bottom: 16%;
	margin-left: 14%;
}
@media only screen and (max-width: 768px) {
	.clinic-text-top {
		margin: auto;
		margin-top: 8%;
		margin-bottom: 18%;
	}
}
.sub-p {
	margin-top: 4%;
}
.clinic-cont-sub {
	width: 100%;
	background-color: #faf8f4;
	padding: 6% 0;
	margin-bottom: 15%;
}
.clinic-cont-sub-area {
	position: relative;
	height: 40vw;
	margin-top: 5%;
}
@media only screen and (max-width: 768px) {
	.clinic-cont-sub-area {
		height: auto;
	}
}
.clinic-cont-sub-box {
	position: absolute;
}
@media only screen and (max-width: 768px) {
	.clinic-cont-sub-box {
		position: initial;
	}
}
.clinic-cont-sub-box h3 {
	text-align: center;
	width: 19%;
	background-image: url("../img/kirin_h3_bk.png");
	background-repeat: no-repeat;	
	color: #fff;
	line-height: 1.4vw;
    background-size: 98%;
    padding: 2.2% 0 3% 0;
	font-size: 1.4vw;
	margin: 0;
}
@media only screen and (max-width: 768px) {
	.clinic-cont-sub-box h3 {
		width: 58px;
		padding: 5px 0 15px 0;
		font-size: 21px;
		line-height: 18px;
	}
}
.h3_sub {
	font-size: 1vw;
}
@media only screen and (max-width: 768px) {
	.h3_sub {
		font-size: 12px;
	}
}
.clinic-cont-sub-h {
	display: flex;
	margin-bottom: 8%;
}
.clinic-cont-sub-h h4 {
	margin-left: 5%;
	margin-top: 4%;
	margin-bottom: 0;
}
@media only screen and (max-width: 1280px) {
	.clinic-cont-sub-h h4 {
		margin-top: 2.5%;
	}
}
@media only screen and (max-width: 768px) {
	.clinic-cont-sub-h h4 {
		font-size: 22px;
		margin-top: 14px;
	}
}
.sub-box01 {
	top: 0 ;
	left: 19%;
	width: 22%;
}
.sub-box02 {
	top: 0 ;
	right: 10%;
	width: 37%;
}
.sub-box02 img {
	width: 100%;
}
.sub-box03 {
	top: 52%;
    left: 26%;
	width: 22%;
}
.sub-box04 {
	top: 72%;
	right: 13%;
	width: 22%;
}
@media only screen and (max-width: 768px) {
	.sub-box01 {
		width: 84%;
		margin: auto;
		margin-top: 40px;
        margin-bottom: 40px;
	}
	.sub-box02 {
		width: 90%;
		margin-left: 10%;
		margin-top: 40px;
        margin-bottom: 40px;
	}
	.sub-box03 {
		width: 84%;
		margin: auto;
		margin-top: 40px;
        margin-bottom: 40px;
	}
	.sub-box04 {
		width: 84%;
		margin: auto;
		margin-top: 40px;
        margin-bottom: 40px;
	}
}
.kirin-flow-box {
	display: flex;
	width: 100%;
	border: #236045 solid 1px;
	border-radius: 6px;
	height: 19.34vw;
}
@media only screen and (max-width: 768px) {
	.kirin-flow-box {
		display: block;
		height: auto;
		padding-bottom: 25px;
	}
}
.kirin-flow-box-img {
	width: 40%;
}
@media only screen and (max-width: 768px) {
	.kirin-flow-box-img {
		width: 100%;
	}
}
.kirin-flow-box-img img {
	width: 100%;
}
.kirin-flow-box-text {
	width: 50%;
	padding-left: 5%;
	padding-right: 5%;
}
@media only screen and (max-width: 768px) {
	.kirin-flow-box-text {
		width: 90%;
	}
}
@media only screen and (max-width: 1480px) {
	.kirin-flow-box-text p {
		margin-top: 0;
		line-height: 28px;
	}
}
@media only screen and (max-width: 980px) {
	.kirin-flow-box-text p {
		font-size: 14px;
		line-height: 21px;
	}
}
.flow-cont-sub-h {
	display: flex;
	margin-top: 2%;
}
.flow-cont-sub-h h3{
	text-align: center;
	background-image: url("../img/kirin_h3_bk.png");
	background-repeat: no-repeat;
	color: #fff;
	background-size: 100%;
	width: 12%;
    line-height: 89%;
    padding: 1% 0 2.5% 0;
}
@media only screen and (max-width: 768px) {
	.flow-cont-sub-h h3{
		width: 19%;
		padding: 0.5% 0 3.2% 0;
	}
}
.step-h3 {
	letter-spacing: -2px;
}
.flow-cont-sub-h h4 {
	margin-left: 5%;
	margin-top: 9%;
}
@media only screen and (max-width: 1480px) {
	.flow-cont-sub-h h4 {
        margin-top: 7%;
    }
}
@media only screen and (max-width: 768px) {
	.flow-cont-sub-h h4 {
		margin-top: 12%;
	}
}
.arrow-box {
	width: 100%;
	text-align: center;
	margin-bottom: 1%;
}
@media only screen and (max-width: 1480px) {
	.arrow-box {
		margin-top: -0.5%;
	}
}
@media only screen and (max-width: 1300px) {
	.arrow-box {
		margin-top: -0.7%;
	}
}
@media only screen and (max-width: 1100px) {
	.arrow-box {
		margin-top: -0.8%;
	}
}
@media only screen and (max-width: 1000px) {
	.arrow-box {
		margin-top: -1.4%;
	}
}
.arrow-box img{
	width: 5%;
}
@media only screen and (max-width: 768px) {
	.arrow-box img{
		width: 14%;
	}
}
.clinic-cont dl {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
@media only screen and (max-width: 768px) {
	.clinic-cont dl {
		display: block;
	}
}
.clinic-cont dt {
	width: 25%;
    padding: 2% 1% 2% 3%;
    margin-bottom: 26px;
    background-color: #236045;
    border-radius: 42px;
    z-index: 10;
	color: #fff;
}
@media only screen and (max-width: 768px) {
	.clinic-cont dt {
		width: 95%;
        padding: 10px 10px 12px 15px;
        font-size: 18px;
		margin-bottom: 0;
	}
}
.clinic-cont dd {
	width: 65%;
	padding: 2% 1% 2% 8%;
	background-color: #faf8f4;
	margin-bottom: 26px;
	margin-left: -3%;
	border-radius: 0 42px 42px 0;
	color: #236045;
}
@media only screen and (max-width: 768px) {
	.clinic-cont dd {
		width: 95%;
        padding: 10px 10px 12px 15px;
		font-size: 14px;
		border-radius: 35px;
		margin-left: 0;
	}
}
.clinic-cont-box h5 {
	font-size: 1.5vw;
}
@media only screen and (max-width: 768px) {
	.clinic-cont-box h5 {
		font-size: 21px;
		margin-bottom: 10px;
	}
}
.kirin-table table {
	width: 100%;
	text-align: center;
	border-collapse: collapse;
}
.kirin-table th {
	background-color: #236045;
	color: #fff;
	font-weight: normal;
	padding: 1% 0;
}
.kirin-table td {
	padding: 1.5% 0;
	border-bottom: solid 1px #236045;
	color: #236045;
}
.sub_td {
	background-color: #faf8f4;
}
.sub_p {
	font-size: 14px;
	line-height: 24px;
}
@media only screen and (max-width: 768px) {
	.sub_p {
		font-size: 12px;
		line-height: 20px;
	}
}
.clinic-cont dl {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
@media only screen and (max-width: 768px) {
	.clinic-cont dl {
		display: block;
	}
}
.jiritsu dt {
	width: 25%;
    padding: 3.3% 1% 2% 3%;
    margin-bottom: 26px;
    background-color: #236045;
    border-radius: 58px;
    z-index: 10;
	color: #fff;
}
@media only screen and (max-width: 768px) {
	.jiritsu dt {
		width: 95%;
        padding: 10px 10px 12px 15px;
        font-size: 18px;
		margin-bottom: 0;
	}
}
.jiritsu dd {
	width: 61%;
	padding: 2% 5% 2% 8%;
	background-color: #faf8f4;
	margin-bottom: 26px;
	margin-left: -3%;
	border-radius: 0 58px 58px 0;
	color: #236045;
}
@media only screen and (max-width: 768px) {
	.jiritsu dd {
		width: 95%;
        padding: 10px 10px 12px 15px;
		font-size: 14px;
		border-radius: 35px;
		margin-left: 0;
	}
}
.jiritsu-sub {
	padding: 3.3% 1% 3.3% 3% !important;
	background-color: #558872 !important;
}
@media only screen and (max-width: 768px) {
	.jiritsu-sub {
		padding: 10px 10px 12px 15px !important;
	}
}
.dd-sub {
	background-color: #ecf2f0 !important;
}
.kirin-map {
	display: flex;
	margin-bottom: -18%;
}
.kirin-map-text {
	width: 45%;
}
.kirin-map-map {
	width: 55%;
	transform: translateY(-23%);
}
.kirin-map-map img {
	width: 100%;
}
@media only screen and (max-width: 768px) {
	.kirin-map {
		display: block;
		margin-bottom: 5%;
	}
	.kirin-map-text {
		width: 100%;
		margin-bottom: 8%
	}
	.kirin-map-map {
		width: 100%;
		transform: translateY(0%);
	}
}
.kirin-info {
	background-color: #e6f4f8;
	padding: 2% 10%;
	border-radius: 10px;
}
.kirin-info ul {
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: space-between;
	margin-bottom: 4%;
	margin-top: 3%;
}
@media only screen and (max-width: 768px) {
	.kirin-info ul {
		display: block;
	}
}
.kirin-info li{
	width: 45%;
}
@media only screen and (max-width: 768px) {
	.kirin-info li{
		width: 100%;
		margin-bottom: 15px;
	}
}
.kirin-info li img {
	width: 100%;	
}
#map-area-kirin {
	text-align: center;
    margin-top: 4%;
}
.philosophy-area {
	display: flex;
	justify-content: space-between;
	margin-bottom: 8%;
}
@media only screen and (max-width: 768px) {
	.philosophy-area {
		display: block;
		margin-bottom: 55px;
	}
}
.philosophy-box {
	width: 25%;
	border: solid 1px #236045;
	border-radius: 24px;
	padding: 2%;
}
@media only screen and (max-width: 768px) {
	.philosophy-box {
		width: 90%;
        margin-bottom: 8%;
        padding: 5%;
	}
}
.philosophy-img img{
	width: 100%;
	margin-bottom: 5%;
}
.philosophy-text {
	line-height: 26px;
}
@media only screen and (max-width: 768px) {
	.philosophy-text {
		line-height: 21px;
	}
}
.pp-area {
	margin-top: 8%;
	margin-bottom: 8%;
}
@media only screen and (max-width: 768px) {
	.pp-area {
		margin-top: 55px;
		margin-bottom: 55px;
	}
}
.pp-area li {
	color: #236045;
	list-style: decimal;
}
.inquiry-text {
	margin-left: 10%;
	margin:  5% 0;
}
.inquiry-area {
	width: 74%;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.inquiry-area {
		width: 100%;
	}
}
.kirin_logo {
	background-image: url("../img/kirin-logo.png") !important;
	background-size: 12% !important;
	padding: 3% 0 2.5% 13% !important;
	margin-top: 3% !important;
}
.houou_logo {
	background-image: url("../img/houou-logo.png")!important;
	padding: 3% 0 2.5% 13% !important;
	background-size: 11% !important;
	margin-top: 3% !important;
}
.datumou_logo {
	background-image: url("../img/datukirin-logo.jpg")!important;
	padding: 3% 0 2.5% 13% !important;
	background-size: 12% !important;
	margin-top: 3% !important;
}
@media only screen and (max-width: 768px) {
	.kirin_logo {
		font-size: 19px !important;
		padding: 3% 0 2.5% 27% !important;
		background-size: 27% !important;
		margin-top: 35px !important;
	}
	.houou_logo {
		font-size: 19px !important;
		padding: 3% 0 2.5% 27% !important;
		background-size: 24% !important;
		margin-top: 35px !important;
	}
	.datumou_logo {
		font-size: 19px !important;
		padding: 3% 0 2.5% 27% !important;
		background-size: 27% !important;
		margin-top: 35px !important;
	}
}
.h6-area {
	text-align: center;
}
@media screen and (max-width: 640px) {
	.h6-area {
		margin-top: 28px;
	}
}
.h6_sbu{
    background-color: #236045;
    color: #fff;
    padding: 1% 5%;
    border-radius: 35px;
    background-size: 10px;
    font-size: 18px;
	
}
@media screen and (max-width: 640px) {
	.h6_sbu{
		padding: 8px 24px;
		font-size: 16px;
	}
}
.kijyun-area {
	border: solid 1px #236045;
	margin-top: -15px;
}
.kijyun-area ul {
	padding: 28px 35px 10px 35px;
}
@media screen and (max-width: 640px) {
	.kijyun-area ul {
		padding:22px 20px 8px 20px;
	}
}
.kijyun-area li {
	margin-bottom: 8px;
	color: #236045;
	background-image: url("../img/kirin-li.png");
	background-repeat: no-repeat;
	background-position: top 50% left 0;
	padding-left: 24px;
}
@media screen and (max-width: 640px) {
	.kijyun-area li {
		background-position: top 9px left 0px;
		background-size: 12px;
        padding-left: 16px;
	}
}
.syorui {
	background-image: url("../img/syorui.png");
	margin-top: 8%;
}
@media screen and (max-width: 640px) {
	.syorui {
		margin-top: 35px;
	}
	.syorui h3 {
		font-size: 21px;
	}
}
.syorui a{
	display: block;
}
.syorui a:hover {
	opacity: 0.6;
	transition-duration: 0.5s;
	background-color:  #FFFFFF;
	color: #fff;
}
.shisetu {
	background-image: url("../img/shisetu.png");
}
.kirin-table02 {
	overflow-x: auto;
}
.kirin-table02 table {
	width: 100%;
	min-width: 600px;
	text-align: center;
	border-collapse: collapse;
}
.kirin-table02 th {
	background-color: #236045;
	color: #fff;
	font-weight: normal;
	padding: 1% 0;
	border-left: #236045 solid 1px;
	border-right: #fff solid 1px;
}
.kirin-table02 th:nth-child(3n){
	border-right: #236045 solid 1px;
}
.kirin-table02 td {
	padding: 1.5% 0;
	border: solid 1px #236045;
	color: #236045;
	line-height: 23px;
}
.sp-text {
	display: none;
	color: #236045;
}
@media screen and (max-width: 640px) {
	.sp-text {
		display: block;
	}
}
ol  {
	position: relative;
	margin: 0;
	padding: 0
}
ol li  {
	list-style: none;
	list-style-position: outside;
	margin: 0;
	padding-left: 1.55em;
	color: rgba(247,18,22,1.00);
	line-height: 21px;
	margin-bottom: 0.5%;
}
@media screen and (max-width: 640px) {
	ol li  {
		margin-bottom: 8px;
	}
}
ol li span {
	position: absolute;
	left: 0;
	margin: 0
}
.sheet-area {
	display: flex;
	justify-content: space-between;
	width:100%;
	font-size: 1.0vw;
}
@media screen and (max-width: 640px) {
	.sheet-area {
		display: block;
	}
}
@media screen and (max-width: 1360px) {
	.sheet-area {
		font-size: 0.9vw;
	}	
}
@media screen and (max-width: 640px) {
	.sheet-area {
		font-size: 14px;
	}	
}
.sheet-area a{
	display: block;
}
.sheet-area a:hover {
	opacity: 0.3;
	transition-duration: 0.5s;
}
.kojin-btn {
	width: 40%;
	color: #236045;
	border: solid #236045 1px;
	padding: 5px;
	padding-left: 50px;
	background-image: url("../img/syorui.png");
	background-size: 35px;
	background-repeat: no-repeat;
	background-position: top 50% left 3%;
	margin-right: 10%;
}
@media screen and (max-width: 640px) {
	.kojin-btn {
		width: 80%;
		margin: auto;
		margin-bottom: 25px;
		margin-top: 25px;
	}
}
.facility-btn {
	width: 40%;
	color: #236045;
	border: solid #236045 1px;
	padding: 5px;
	padding-left: 50px;
	background-image: url("../img/shisetu.png");
	background-size: 35px;
	background-repeat: no-repeat;
	background-position: top 50% left 3%;
}
@media screen and (max-width: 640px) {
	.facility-btn {
		width: 80%;
		margin: auto;
	}
}
.step01 {
	    height: 23.34vw;	
}
@media screen and (max-width: 1680px) {
	.step01 {
	    height: 27.34vw;
	}
}
@media screen and (max-width: 640px) {
	.step01 {
	    height: auto;
	}
}
.step01-img {
	margin-top: 3%;
}
@media screen and (max-width: 1680px) {
	.step01-img {
		margin-top: 5%;
	}
}
.kirin-table03 {
	overflow-x: auto;
}
.kirin-table03 table {
	width: 100%;
	min-width: 600px;
	text-align: center;
	border-collapse: collapse;
}
.kirin-table03 th {
	background-color: #236045;
	color: #fff;
	font-weight: normal;
	padding: 1% 0;
	border-left: #236045 solid 1px;
	border-right: #fff solid 1px;
}
.kirin-table03 th:nth-child(2n){
	width: 20%;
}
.kirin-table03 th:nth-child(3n){
	width: 15%;
}
.kirin-table03 th:nth-child(4n){
	border-right: #236045 solid 1px;
	width: 40%;
}
.kirin-table03 td {
	padding: 1.5% 0;
	border: solid 1px #236045;
	color: #236045;
	line-height: 23px;
}
@media screen and (max-width: 640px) {
	h6 {
		margin-bottom: 8px;
	}
}