@charset "UTF-8";


/*共通スタイル
---------------------------------------------------------*/
/****メインイメージ****/
.contentpage .m_img_area .m_title {
	font-size: min(2.2vw, 176%);
	letter-spacing: .25em;
	line-height: 1.2em;
}
.contentpage .m_img_area .m_title .ft_cy_b {
	font-size: 100%;
	margin-bottom: 0;
}
.contentpage .m_img_area .m_title .fw_bold {
	font-size: 200%;
	letter-spacing: .25em;
	line-height: 1.2em;
	margin-bottom: .4em;
}
.contentpage .m_img_area .m_title .ft_cy_b:first-letter {
	color: inherit;
}
.contentpage .m_img_area .m_title .fw_bold:first-letter {
	color: #f7c7c9;
}



/* 画像・テキストレイアウト */
.med_flt > .img_l,
.med_flt > .txt_l {
	float: left;
}
.med_flt > .img_r,
.med_flt .txt_r {
	float: right;
}
.med_flt > .img_l,
.med_flt > .img_r {
	width: 36.7%;
	max-width: 440px;
	margin: 0;
}
.med_flt > .txt_l,
.med_flt > .txt_r {
	width: 60%;
}



/****見出し****/
/* インデックス1 */
.med_index1 {
	position: relative;
	max-width: 1280px;
    text-align: center;
    color: #866d5a;
    font-size: min(2.5vw,176%);
	font-weight: 600;
    letter-spacing: .15em;
    line-height: 1.4em;
    padding: 1.6em 0 1em;
    margin: 0 auto 50px;
    border-top: solid 1px #866d5a;
    border-bottom: solid 1px #866d5a;
}
.med_index1 span {
	position: absolute;
	display: inline-block;
	font-family: "termina", sans-serif;
    font-weight: 400;
	background: #f5f2e8 url("../images/medical/index1_abs.svg") no-repeat left 8% top;
	background-size: 40% auto;
	font-size: 183%;
	left: 50%;
	top: 0;
	transform: translate(-50%,-50%);
	padding: .45em 1.2em;
}


/* スタイル1：25px */
.med_style1 > dt {
	font-weight: 600;
	font-size: min(2.5vw,176%);
	letter-spacing: .14em;
	line-height: 1.6;
	margin-bottom: .6em;
}

/* スタイル2 - アイコン付き：20px*/
.med_style2 > dt,
.med_style2_txt {
	position: relative;
	color: #45371e;
	font-weight: 600;
	font-size: min(1.8vw,135%);
	line-height: 1.6;
	padding-left: 1.1em;
}
.med_style2 > dt {
	margin-bottom: .5em;
}
.med_style2 > dt::before,
.med_style2_txt::before {
	position: absolute;
	content: "";
	background-color: #d9936a;
	width: .6em;
	height: 5px;
	border-radius: 5px;
	left: 0;
	top: .6em;
}
.med_style2 > dt span {
	font-size: 87%;
}

/* スタイル3 - 26px ▶ 20px*/
.med_style3 > dt {
	position: relative;
	color: #6bc3d8;
	font-size: min(2.2vw,152%);
	font-weight: 600;
	letter-spacing: .15em;
	line-height: 1.5;
	margin-bottom: .7em;
}
.med_style3 > dt span {
	display: inline-block;
	font-size: 77%;
}

/****レイアウト****/

/* ボックスリスト */
.med_boxlist .list_box {
	padding-bottom: 50px;
	border-bottom: solid 1px #bdb8b6;
	margin-bottom: 50px;
}
.med_boxlist .list_box:last-of-type {
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}


.bdr_b {
	padding-bottom: 60px;
	border-bottom: solid 1px #bdb8b6;
	margin-bottom: 60px;
}

.com_link3.center {
    margin-left: auto;
    margin-right: auto;
}

.asterisk {
	position: relative;
	color: #9e998e;
	font-size: 88%;
	line-height: 1.7;
	padding-left: 1em;
	margin-top: 1.5em;
}
.asterisk::before {
	position: absolute;
	content: "※";
	width: 1em;
	height: 1em;
	left: 0;
	top: 0;
}


/* PC調整
------------------------------------------*/
@media only screen and (min-width: 960px) and (max-width: 1200px) {
.med_style2 > dt,
.med_style2_txt {
	font-feature-settings: "halt";
}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {


/* 画像・テキストレイアウト */
.med_flt .img_l,
.med_flt .img_r {
	margin-bottom: 1.0em;
}
.med_flt .img_l {
	margin-right: 3%;
}
.med_flt .img_r {
	margin-left: 3%;
}
.med_flt .txt_l,
.med_flt .txt_r {
	width: 100% !important;
	max-width: 100%;
	float: none;
}

	
/* インデックス1 */
.med_index1 {
    margin-bottom: 6%;
}


/* スタイル1 */
.med_style1 > dt {
	font-size: 2.8vw;
	letter-spacing: .05em;
}
	
/* スタイル2 - アイコン付き：25px*/
.med_style2 > dt,
.med_style2_txt {
	font-size: 2.1vw;
	font-feature-settings: "halt";
}
/* スタイル3 - 20px ▶ 25px*/
.med_style3 > dt {
	font-size: 2.5vw;
	letter-spacing: .05em;
}
	

/* ボックスリスト */
.med_boxlist .list_box {
	padding-bottom: 5%;
	margin-bottom: 5%;
}

.bdr_b {
	padding-bottom: 6%;
	margin-bottom: 6%;
}
	
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.contentpage .m_img_area .m_title {
	font-size: 90%;
}
.contentpage .m_img_area .m_title .fw_bold {
	font-size: 180%;
	letter-spacing: .1em;
}
	

/* 画像・テキストレイアウト */
.med_flt .img_l,
.med_flt .img_r {
	width: 70%;
	margin: 0 auto 1.5em;
	float: none;
}
.med_flt .sp_img_w {
	width: 90%;
}
.med_flt .txt_l,
.med_flt .txt_r {
	width: 100% !important;
	max-width: 100% !important;
	float: none;
}
	
	
/* インデックス1 */
.med_index1 {
    font-size: 120%;
    letter-spacing: .1em;
    padding: 1.6em 0 1em;
    margin-bottom: 7%;
	margin-top: 14%;
}
.med_index1 span {
    font-size: 160%;
}

/* スタイル1 */
.med_style1 > dt {
	font-size: 125%;
	letter-spacing: .05em;
}

/* スタイル2 - アイコン付き：25px*/
.med_style2 > dt,
.med_style2_txt {
	font-size: 110%;
}
/* スタイル3 - 20px ▶ 25px*/
.med_style3 > dt {
	font-size: 115%;
	letter-spacing: .1em;
}
.med_style3 > dt::before {
	top: .08em;
}

/* ボックスリスト */
.med_boxlist .list_box {
	padding-bottom: 7%;
	margin-bottom: 7%;
}

.bdr_b {
	padding-bottom: 8%;
	margin-bottom: 8%;
}

}


/* lead
---------------------------------------------------------*/
.lead_grd {
	position: relative;
}
.lead_grd::after {
	position: absolute;
	content: "";
	background: linear-gradient(to bottom,rgba(238,234,177,0.5) 30%,#f5f2e8);
	width: 100%;
	height: calc(100% - 80px);
	left: 0;
	top: 80px;
}
.lead_grd > * {
	position: relative;
	z-index: 1;
}
.lead_img {
	width: 70%;
	max-width: 862px;
	margin: 0 auto 1em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.lead_grd::after {
	height: calc(100% - 60px);
	top: 60px;
}	
}
	
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.lead_grd::after {
	height: calc(100% - 2em);
	top: 2em;
}
.lead_img {
	width: 100%;
}
	
}



/* ピックアップボックス
---------------------------------------------------------*/
.med_pickup {
	width: 100%;
	box-sizing: border-box;
}
.med_pickup .pick_title {
	text-align: center;
	color: #FFF;
	font-size: 141%;
	background-color: #6bc3d8;
	padding: 1.2em 0;
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
}
.med_pickup .pick_box {
	background-color: #FFF;
	padding: 50px 4.5%;
}
.med_pickup .pick_box .pick_inbox {
	padding-bottom: 50px;
	border-bottom: #b2ada5 1px solid;
	margin-bottom: 50px;
}
.med_pickup .pick_box .pick_inbox:last-of-type {
	padding-bottom: 0;
	border-bottom: none;
	margin-bottom: 0;
}

.med_pickup .med_flt .img_l,
.med_pickup .med_flt .img_r {
	width: 37.1%;
	max-width: 400px;
}
.med_pickup .med_flt .txt_l,
.med_pickup .med_flt .txt_r {
	width: 60%;
}

.med_pickup .pick_col3 {
	display: flex;
	justify-content: space-between;
}
.med_pickup .pick_col3 > div {
	width: 31%;
}
.med_pickup .pick_col3 .med_style2 {
	margin-bottom: 1.8em;
}
.med_pickup .pick_col3 .box_img {
	margin: 0 auto;
}
.med_pickup .pick_col3 .med_style2 dd p {
	font-feature-settings: "halt";
}

.med_pickup .med_flow_list {
	max-width: 930px;
}

.med_pickup .pick_point {
	display: flex;
	background-color: #76b38d;
}
.med_pickup .pick_point dt {
	align-self: center;
	color: #FFF;
	font-size: 176%;
	letter-spacing: .15em;
	box-sizing: border-box;
	padding: 30px .6em;
}
.med_pickup .pick_point dd {
	background-color: #f5f2e8;
	box-sizing: border-box;
	padding: 40px 3%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_pickup .pick_title {
	font-size: 130%;
}
.med_pickup .pick_box {
	padding: 5% 3%;
}
.med_pickup .pick_box .pick_inbox {
	padding-bottom: 5%;
	margin-bottom: 5%;
}
.med_pickup .point > dt {
	font-size: 130%;
	letter-spacing: .2em;
}
	
.med_pickup .pick_col3 > div {
	width: 32%;
}
	
.med_pickup .pick_point dt {
	font-size: 150%;
	letter-spacing: .1em;
	padding: 20px 1em;
}
.med_pickup .pick_point dd {
	padding: 25px 3%;
}

}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) {
	
.med_pickup .pick_title {
	font-size: 120%;
	padding: 1em 0;
}
.med_pickup .pick_box {
	padding: 6% 4.5% 8%;
}
.med_pickup .pick_box .pick_inbox {
	padding-bottom: 8%;
	margin-bottom: 8%;
}
	
.med_pickup .med_flt .img_l,
.med_pickup .med_flt .img_r {
	width: 70%;
}
.med_pickup .med_flt .sp_img_w {
	width: 80%;
}

.med_pickup .pick_col3 {
	display: block;
}
.med_pickup .pick_col3 > div {
	width: 100%;
}
.med_pickup .pick_col3 > div:not(:last-of-type) {
	border-bottom: solid 1px #c7c6c4;
	padding-bottom: 8%;
    margin-bottom: 8%;
}
.med_pickup .pick_col3 > div .box_img {
	width: 70%;
}
.med_pickup .pick_col3 .ft_serif {
	font-size: 115%;
	letter-spacing: .1em;
	margin-top: .5em;
}
	
.med_pickup .pick_point {
	display: block;
}
.med_pickup .pick_point dt {
	text-align: center;
	font-size: 120%;
	letter-spacing: .15em;
	padding: .8em 0;
}
.med_pickup .pick_point dd {
	padding: 5% 4%;
}


}



/* med_point
---------------------------------------------------------*/
.med_point {
	width: 100%;
	background-color: #f5f2e8;
	box-sizing: border-box;
	padding: 40px 5% 55px;
}
.med_point dt {
	text-align: center;
	font-size: 141%;
	margin-bottom: 1.2em;
}
.med_point dt span {
	font-size: 75%;
}
.med_point .med_flt .img_l,
.med_point .med_flt .img_r {
	width: 37.1%;
	max-width: 400px;
}
.med_point .med_flt .txt_l,
.med_point .med_flt .txt_r {
	width: 60%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.med_point {
	padding: 5% 3.5%;
}
.med_point dt {
	font-size: 125%;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) {
.med_point {
	padding: 7% 5%;
}
.med_point dt {
	font-size: 115%;
	margin-bottom: .8em;
}
.med_point .med_flt .img_l,
.med_point .med_flt .img_r {
	width: 80%;
}
	
}

/*流れ
---------------------------------------------------------*/
.med_flow {
	background-color: #FFF;
	padding: 40px 3%;
}
.med_flow .flow_title {
	text-align: center;
	color: #06768f;
	font-size: 147%;
	line-height: 1.6;
	margin-bottom: 1em;
}
.med_flow .med_flow_list {
	max-width: 950px;
}
.med_flow_list {
	width: 100%;
	max-width: 950px;
	display: flex;
    justify-content: center;
	margin: 0 auto;
}
.med_flow_list li {
	position: relative;
	width: 19.5%;
	box-sizing: border-box;
}
.med_flow_list li.arrow {
	position: relative;
	width: 7%;
	padding-bottom: 0;
}
.med_flow_list li.arrow i {
	position: absolute;
	font-size: 100%;
	color: #866d5a;
	left: 50%;
	top: 28%;
	transform: translateX(-50%);
}
.med_flow_list .img_item {
	position: relative;
	max-width: 185px;
	margin: 0 auto 1.5em;
}
.med_flow_list .txt {
	position: relative;
	text-align: center;
	padding-bottom: 2.5em;
}
.med_flow_list .txt span {
	position: absolute;
	font-size: 88%;
	line-height: 1.5em;
	white-space: nowrap;
	left: 50%;
	transform: translateX(-50%);
}
/*5列*/
.med_flow_list.col5 {
	max-width: 914px;
}
.med_flow_list.col5 li {
	width: 15.4%;
}
.med_flow_list.col5 li.arrow {
	width: 6%;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_flow {
	padding: 4% 3%;
}
.med_flow_list.col5 li.arrow i {
	top: 23%;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.med_flow {
	padding: 8% 3.5%;
}
.med_flow .flow_title {
	font-size: 120%;
	letter-spacing: .05em;
}
.med_flow_list {
	display: block;
	width: 90%;
}
.med_flow_list li {
	width: 100% !important;
	max-width: 100%;
	display: flex;
    justify-content: space-between;
    align-items: center;
}
.med_flow_list li.arrow {
	display: block;
	width: 100% !important;
	margin: 0;
}
.med_flow_list li.arrow i {
	position: relative;
	display: inline-block;
	top: 0;
	transform: translateX(-50%) rotate(90deg);
}
.med_flow_list .img_item {
	width: 40%;
	margin: 0;
}
.med_flow_list .txt {
	width: 55%;
	text-align: left;
	letter-spacing: normal;
	left: auto;
	transform: none;
	padding-bottom: 0;
}
.med_flow_list .txt span {
	position: relative;
	letter-spacing: normal;
	left: auto;
	transform: none;
	padding-bottom: 0;
}
	

	
}



/*チェック
---------------------------------------------------------*/
.med_check {
	position: relative;
	box-sizing: border-box;
	padding: 60px 4.5% 50px;
	border: 4px solid #ded8c1;
}
.med_check::before {
	position: absolute;
	content: "CHECK";
	color: #e8e2ca;
	text-align: center;
	font-family: "termina", sans-serif;
    font-weight: 400;
	font-style: normal;
	font-size: min(5.8vw,370%);
	letter-spacing: .25em;
	line-height: 1;
	background-color: #f5f2e8;
	width: 6.3em;
	height: 1em;
	padding-left: .5em;
	padding-right: .2em;
	left: 50%;
	top: 0;
	transform: translate(-50% , -50%);
}
.med_check .check_title {
	text-align: center;
	font-size: min(1.8vw,129%);
	font-weight: 600;
	margin-bottom: 3.5em;
}
.med_check .check_title .txt1 {
	letter-spacing: .15em;
	margin-bottom: .5em;
}
.med_check .check_title .txt2 {
	color: #6bc3d8;
	font-size: 181%;
	font-weight: 600;
	letter-spacing: .15em;
}
.med_check .check_title .txt2 span {
	position: relative;
	padding-right: 1em;
}
.med_check .check_title .txt2 span::before {
	position: absolute;
	content: "";
	background-color: #FFF;
	width: .8em;
	height: .8em;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}
.med_check .check_title .txt2 span::after {
	position: absolute;
	content: "";
	background:url("../images/medical/check.svg") no-repeat left top;
	width: .8em;
	height: .8em;
	right: -0.2em;
	top: calc(50% - 0.05em);
	transform: translateY(-50%);
}
.med_check .check_list {
	max-width: 1075px;
	margin: 0 auto;
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.med_check .check_list li {
	position: relative;
	width: 48%;
	font-size: 111%;
	line-height: 1.5;
	box-sizing: border-box;
	padding-left: 2.2em;
	padding-bottom: 1.1em;
	border-bottom: 1px dashed #b2ada5;
}
.med_check .check_list li:nth-of-type(n+3) {
	margin-top: 1.4em;
}
.med_check .check_list li::before {
	position: absolute;
	content: "";
	background-color: #FFF;
	width: 1.2em;
	height: 1.2em;
	left: 0;
	top: .1em;
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}

.med_check .check_txt {
	text-align: center;
	font-size: 129%;
	font-weight: 600;
	letter-spacing: .15em;
	line-height: 1.8;
	margin-top: 1.8em;
}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_check {
	padding: 5% 3.5%;
}
.med_check .check_title {
	margin-bottom: 2.5em;
}
.med_check .check_title .txt1 {
	letter-spacing: .1em;
}
.med_check .check_title .txt2 {
	letter-spacing: .1em;
}
.med_check .check_list li {
	width: 48.5%;
	font-size: 100%;
	letter-spacing: 0;
}
.med_check .check_txt {
	font-size: 110%;
	letter-spacing: .1em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
	
.med_check {
	padding: 10% 4% 8%;
	border-width: 3px;
}
.med_check::before {
	font-size: 8vw;
	letter-spacing: .15em;
}
.med_check .check_title {
	font-size: 3.8vw;
	margin-bottom: 2em;
}
.med_check .check_title .txt1 {
	letter-spacing: .05em;
	margin-bottom: .2em;
}
.med_check .check_title .txt2 {
	font-size: 150%;
	letter-spacing: .05em;
}
.med_check .check_list {
	display: block;
}
.med_check .check_list li {
	width: 100%;
	font-size: 100%;
	padding-left: 2em;
	padding-bottom: .8em;
}
.med_check .check_list li:nth-of-type(n+2) {
	margin-top: 1em;
}
.med_check .check_txt {
	font-size: 100%;
	letter-spacing: .05em;
}
	
}



/*med_col_list
---------------------------------------------------------*/
.med_col_list {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.med_col_list > li {
	background-color: #FFF;
	box-sizing: border-box;
	padding: 35px 2.4% 30px;
	border-radius: 20px;
}
.med_col_list.col2 > li {
	width: 49.1%;
	padding: 35px 3.3% 30px;
}
.med_col_list.col3 > li {
	width: 32.5%;
}
.med_col_list.col2 > li:nth-child(n+3),
.med_col_list.col3 > li:nth-child(n+4) {
	margin-top: .8em;
}

.med_col_list dt {
	text-align: center;
	font-size: 176%;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: .15em;
	font-feature-settings: "halt";
	margin-bottom: .7em;
}

/*アイコン付き*/
.med_col_list.icon > li {
	padding-top: 60px;
}
.med_col_list.icon dt {
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 5.6em auto;
	padding-top: 3em;
}

/* PC調整
------------------------------------------*/
@media only screen and (min-width: 960px) and (max-width: 1050px) {
.med_col_list.icon dt {
	font-size: 2.3vw;
}	
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_col_list > li {
	padding: 25px 2%;
}
.med_col_list.col2 > li {
	padding: 25px 2.8%;
}
.med_col_list dt {
	font-size: 140%;
}	
/*アイコン付き*/
.med_col_list.icon > li {
	padding-top: 40px;
}
	
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.med_col_list {
	display: block;
}
.med_col_list > li {
	width: 100% !important;
	padding: 7% 5% 6%;
	margin-top: 3%;
}
.med_col_list > li:first-child {
	margin-top: 0;
}
.med_col_list.col2 > li {
	padding: 7% 4%;
}
.med_col_list dt {
	font-size: 130%;
}
	
/*アイコン付き*/
.med_col_list.icon > li {
	padding-top: 7%;
}

	
}



/*よくある質問
---------------------------------------------------------*/
.med_faq > dt,
.med_faq > dd {
	box-sizing: border-box;
	padding-left: 7.5%;
	padding-top: .5rem;
}
.med_faq > dt {
	background: url("../images/faq_q.svg") no-repeat left 1.4% top;
	background-size: 2.8rem auto;
	font-size: 147%;
	line-height: 1.5;
	padding-bottom: .5rem;
	margin-bottom: 2rem;
	border-bottom: 1px solid #dee4d2;
}
.med_faq > dd {
	background: url("../images/faq_a.svg") no-repeat left 1.4% top;
	background-size: 2.9rem auto;
	margin-bottom: 50px;
}
.med_faq > dd:last-child {
	margin-bottom: 0;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_faq > dt,
.med_faq > dd {
	padding-top: .2rem;
}
.med_faq > dt {
	font-size: 125%;
	background-size: 2rem auto;
	margin-bottom: 1.5rem;
}
.med_faq > dd {
	margin-bottom: 4%;
	background-size: 2.2rem auto;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.med_faq > dt,
.med_faq > dd {
	padding-top: 0;
	padding-left: 13%;
}
.med_faq > dt {
	font-size: 110%;
	background-size: 1.8rem auto;
	margin-bottom: 1.5rem;
}
.med_faq > dd {
	margin-bottom: 8%;
	background-size: 2rem auto;
}

}



/*med_flow_vertical
---------------------------------------------------------*/
.med_flow_vertical > li {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	padding-left: 80px;
	padding-bottom: 40px;
	margin-bottom: 20px;
}
.med_flow_vertical li:last-of-type {
	padding-bottom: 0;
}
.med_flow_vertical > li::before {
	content: "";
	position: absolute;
	z-index: 0;
	width: 1px;
	height: 100%;
	left: 30px;	
	top: 0;
	background-color: #d1c9a8;
}
.med_flow_vertical li:last-of-type::before {
	display: none;
}
.med_flow_vertical > li .no {
	display: block;
	position: absolute;
	width: 60px;
	text-align: center;
	color: #d1c9a8;
	font-size: 235%;
	line-height: 1;
	background-color: #f5f2e8;
	padding: .1em 0 .5em;
	left: 0;
}

.med_flow_vertical .img_r {
	width: 33.1%;
    max-width: 370px;
}
.med_flow_vertical .txt_l {
	width: 61%;
}
.med_flow_vertical .med_style1 dt {
	color: #866d5a;
}
.med_flow_vertical .flow_point {
	background-color: #d9ebd8;
	box-sizing: border-box;
	padding: 40px 3.5%;
	margin-top: 30px;
}
.med_flow_vertical .flow_point dt {
	color: #76b38d;
	font-size: 135%;
	letter-spacing: .2em;
	margin-bottom: .3em;
}
.med_flow_vertical .flow_point .img_r {
	width: 39%;
	max-width: 395px;
}
.med_flow_vertical .flow_point .txt_l {
	width: 58%;
}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_flow_vertical > li {
	padding-left: 50px;
	padding-bottom: 4%;
	margin-bottom: 2%;
}
.med_flow_vertical > li::before {
	left: 20px;	
}
.med_flow_vertical > li .no {
	width: 40px;
    font-size: 200%;
	padding-top: .05em;
}

.med_flow_vertical .img_r {
	width: 38%;
}
.med_flow_vertical .flow_point {
	padding: 4% 3.5%;
	margin-top: 3%;
}
.med_flow_vertical .flow_point dt {
	font-size: 110%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.med_flow_vertical > li {
	padding-left: 2.5em;
	padding-bottom: 8%;
}
.med_flow_vertical > li::before {
	left: 1em;	
}
.med_flow_vertical > li .no {
	width: 1em;
	font-size: 200%;
	padding-top: 0;
}

.med_flow_vertical .img_r {
	width: 70%;
	margin: 0 auto 1em;
	float: none;
}
.med_flow_vertical .txt_l {
	width: 100%;
}
	
.med_flow_vertical .com_link1 {
	text-align: left;
}
	
.med_flow_vertical .flow_point {
	padding: 7% 5.1%;
	margin-top: 5%;
}
.med_flow_vertical .flow_point dt {
	font-size: 105%;
	letter-spacing: .05em;
}
.med_flow_vertical .flow_point .img_r {
	width: 100%;
}
	
}



/*メリット・デメリット
---------------------------------------------------------*/
.med_merit_demerit {
	display: flex;
    justify-content: space-between;
}
.med_merit_demerit > dl {
	width: 47.5%;
/*	background-color: rgba(107,195,216,0.15);*/
	background-color: #e4ece4;
}
.med_merit_demerit > dl > dt {
	text-align: center;
	background-color: #6bc3d8;
	color: #FFF;
	font-size: 125%;
	font-weight: 600;
	letter-spacing: .1em;
	padding: .3em 0;
}
.med_merit_demerit > dl > dd {
	padding: 1em 4% 1.7em;
}
.med_merit_demerit > dl > dd ul {
	width: 100%;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
}
.med_merit_demerit > dl.demerit {
	background-color: #e4e4dc;
}
.med_merit_demerit > dl.demerit > dt {
	background-color: #b3b3b3;
}

.med_merit_list,
.med_demerit_list {
	font-size: 95%;
	line-height: 1.4;
}
.med_merit_list li,
.med_demerit_list li {
	position: relative;
	letter-spacing: .1em;
	margin-bottom: .8em;
	padding-left: 1.3em;
}
.med_merit_list li:last-child,
.med_demerit_list li:last-child {
	margin-bottom: 0;
}
.med_merit_list li::before,
.med_demerit_list li::before {
	font-family: 'fontello';
	position: absolute;
	font-size: 95%;
	left: 0;
	top: .03em;
}
.med_merit_list li::before {
	content: '\e80a';
	color: #6bc3d8;
}
.med_demerit_list li::before {
	content: '\e80b';
	color: #b3b3b3;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.med_merit_demerit > dl > dt {
	font-size: 110%;
}
.med_merit_demerit > dl > dd {
	padding: 1em 4% 1.5em;
}
.med_merit_list li,
.med_demerit_list li {
	letter-spacing: .1em;
	margin-bottom: .5em;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.med_merit_demerit {
	display: block;
}
.med_merit_demerit > dl {
	width: 100%;
	margin-top: 3%;
}
.med_merit_demerit > dl:first-of-type {
	margin-top: 0;
}
.med_merit_demerit > dl > dt {
	font-size: 110%;
}
.med_merit_demerit > dl > dd {
	padding: .8em 4% 1.2em;
}
.med_merit_demerit > dl > dd ul {
	max-width: 100%;
}

.med_merit_list,
.med_demerit_list {
	letter-spacing: .05em;
	line-height: 1.6em;
}
.med_merit_list li,
.med_demerit_list li {
	margin-bottom: .5em;
}
}






/*
---------------------------------------------------------*/

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
}




/* med_rank
---------------------------------------------------------*/
.med_rank {
	width: 95%;
	max-width: 688px;
	background-color: #FFF;
	border-radius: 2em;
    padding: .5em 2em;
    box-sizing: border-box;
	margin-bottom: 1em;
}
.med_rank li {
	font-size: 117%;
	font-weight: 600;
    display: inline-block;
    margin-right: 1em;
}
.med_rank li:last-child{
    margin-right:0;
}
.med_rank li span {
    font-weight: normal;
    color: #6bc3d8;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.med_rank {
    padding: .4em 2em;
}
.med_rank li {
	font-size: 105%;
}
}

/* Mobile (Portrait) 
------------------------------------------*/ 
@media only screen and (max-width: 767px) {
.med_rank {
	width: 100%;
    padding: .5em 1.5em;
	margin-bottom: 1em;
}
.med_rank li {
	font-size: 100%;
    margin-right: .8em;
}
}




/*med_footer
---------------------------------------------------------*/
.med_footer {
	padding: 60px 0 70px;
	background-color: #69b6db;
}
.med_footer .med_f_title {
	text-align: center;
	color: #3678ac;
	font-size: min(3.5vw,294%);
	letter-spacing: .2em;
	margin-bottom: .5em;
}
.med_footer .menu_list {
	display: flex;
    flex-wrap: wrap;
	max-width: 1305px;
}
.med_footer .menu_list li {
	position: relative;
	width: 22.8%;
	margin-right: 2.9%;
}
.med_footer .menu_list li:nth-of-type(4n) {
	margin-right: 0;
}
.med_footer .menu_list li:nth-of-type(n+5) {
	margin-top: .2em;
}
.med_footer .com_medical li[class^="icon"] {
    font-size: min(1.5vw,125%);
    letter-spacing: .05em;
}
.med_footer .com_menu a {
	font-size: min(1.3vw,120%);
    padding: 1.1em 0;
	margin-top: 1em;
}

/* PC調整
------------------------------------------*/
@media only screen and (min-width: 960px) and (max-width: 1160px) {


}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.med_footer {
	padding: 6% 0 7%;
}
.med_footer .med_f_title {
	letter-spacing: .15em;
}
.med_footer .menu_list li {
	width: 24%;
	margin-right: 1.3%;
}
.med_footer .menu_list li:nth-of-type(n+5) {
	margin-top: .2em;
}
.med_footer .com_medical li[class^="icon"] {
    font-size: 1.8vw;
	letter-spacing: .05em;
}
.med_footer .com_medical li[class^="icon"] a {
    padding: 1.2em 2.5em;
    padding-right: 0;
}
.med_footer .com_medical li[class^="icon"] a::before {
	left: -0.5em;
}
.med_footer .com_menu a {
    font-size: 1.8vw;
	margin-top: .4em;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.med_footer {
	padding: 8% 0 9%;
}
.med_footer .med_f_title {
	font-size: 180%;
	letter-spacing: .1em;
}
.med_footer .menu_list li {
	width: 48%;
	margin-right: 2%;
}
.med_footer .menu_list li:nth-of-type(n+3) {
	margin-top: .2em;
}
.med_footer .com_medical li[class^="icon"] {
    font-size: 3.5vw;
	letter-spacing: .05em;
}
.med_footer .com_medical li[class^="icon"] a {
    padding: 1.2em 2.5em;
    padding-right: 0;
}
.med_footer .com_medical li[class^="icon"] a::before {
	left: -0.5em;
}
.med_footer .com_menu a {
    font-size: 3.5vw;
	margin-top: .4em;
}

}