@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;500;700; 800; 900&display=swap');
/* CSS Document */

html{
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
}


.page_title {
	color: #fff;
}

p{
	margin-bottom: 0;
}

.btn_b,
.btn_w{
	display: flex;
	align-items: center;
	justify-content: center;
	gap:20px;
}
.btn_b a,
.btn_w a{
	min-width: 200px;
	padding: 5px;
	border-radius: 50px;
	text-align: center;
	display: block;
	color: #fff;
    font-size: 14px;
    font-family: inherit;
	font-weight: 700;
}
.btn_b a{
	border: solid 1px #0071bc;
	background-color: #0071bc;
	color: #fff;
	text-decoration: none;
}
.btn_w a{
	border: solid 1px #fff;
	background-color: #fff;
	color: #0071bc;
	text-decoration: none;
}
.btn_b a:hover{
	text-decoration: none;
	background-color: #fff;
	color: #0071bc;
}
	
.btn_w a:hover{
	text-decoration: none;
	background-color: #0071bc;
	color: #fff;
}

    #main > .container {
        width: 100% !important;
        padding: 0 !important;
    }
.inner{
	max-width: 1240px;
	padding: 0 20px;
	margin: auto;
}
h3{
	font-size: 26px;
	font-weight: 700;
	margin-bottom: 30px;
	text-align:center;
	padding: 0;
}
h3:before,
h3:after{
	display: none;
}



@media (min-width: 1201px) {
    .container {
        width: 1240px;
	}
}
@media (min-width: 701px) {

.archive_flex{
	display: flex;
	align-items: flex-start;
	gap:50px;
}
.archive_flex .left{
	width: 100%;
}
.archive_flex .right{
	flex-shrink: 0;
	width: 240px;
}
}
.archive_flex .right{
	margin-bottom:  40px;
	padding: 20px;
	border: solid 1px #333;
}
.side_catlist{
	list-style: none;
	padding: 0;
}
.side_catlist a{
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
	color: #003E8F;
}
.side_catlist a.active{
	font-weight: 800;
}
.side_taglist{
	list-style: none;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0px;
	column-gap: 10px;
}

.side_taglist a{
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
}
.side_taglist a.active{
	font-weight: 800;
}
.archive_flex .right p.side_title{
	font-weight: 800;
	margin-top: 40px;
	margin-bottom: 10px; 
	background-image: url("../images/header/search_icon_b.svg");
	padding-left: 1.5em;
	background-size: 1em auto;
	background-repeat: no-repeat;
	background-position: left center;
}
.archive_flex .right p.side_title:first-child{
	margin-top: 0;
}
.archive_flex .right a,
.archive_flex .right a:active,
.archive_flex .right a:visited,
.archive_flex .right a:active{
	font-size: 14px;
	color: #003E8F;
}
.archive_flex .right a:hover{
	color: #003E8F;
	text-decoration: underline;
}


.four_col{
	display: flex;
	flex-wrap: wrap;
	gap:30px;
	list-style: none;
	padding: 0;
    margin-bottom: 40px;
}
.four_col > li{
	width: calc(33.33% - 30px * 2 / 3);
}

.banner_four_col{
	display: flex;
	flex-wrap: wrap;
	gap:20px;
	list-style: none;
	padding: 0;
}
.banner_four_col > li{
	width: calc(25% - 20px * 3 / 4);
}
.info_two_col{
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: #fff;
	max-width: 1200px;
	margin: auto;
	margin-bottom: 40px;
	gap:40px;
}
.info_two_col .left{
	flex-shrink: 0;
	width: calc(50% - 20px);
}
#join_info h3,
#info_service h3{
	color: #fff;
	text-align: left;
	width: 100%;
	margin-bottom: 20px;
}
#join_info p,
#info_service p{
	font-size: 16px;
}
.three_col{
	display: flex;
	border-left: solid 1px #fff;
	width: 100%;
}
.three_col > div{
	width: 33.33%;
	padding: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding-bottom: 0;
	border-right: solid 1px #fff;
	gap:20px;
}
@media (min-width: 701px) {
#info_service .three_col > div{
	justify-content: flex-start;
	padding-bottom: 80px;
	position: relative;
	}
	#info_service .btn_w{
		position: absolute;
		left: 0;
		right: 0;
		bottom: 20px;;
		margin: auto;
	}
}
#info_service .btn_w a{
		font-weight: 700;
}
.three_col h4{
	color: #fcee21;
	padding: 0;
	margin-bottom: 0;
}

.join_two_col{
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: #fff;
	gap:40px;
	margin: auto;
	max-width: 1200px;
}

@media (min-width: 1001px) {
	.join_two_col .left{
		width: 33.33%;
	}	
	.join_two_col .right{
		width: 66.66%;
	}	
}
.banner_two_col_slide li{
	display: flex;
	gap:20px;
}
.banner_two_col_slide li{
	width: calc(50% - 10px);
}
.listitem_box{
	background-color: #eaf5ff;
	border-radius: 0 0 15px 15px;
	box-shadow: 0px 0px 8px -4px #969696;
	line-height: 1.4;
    border-radius: 0 10px 10px 10px;
    border-radius:  10px;
	overflow: hidden;
}
.listitem_box a:hover{
	text-decoration: none;
	opacity: 0.6;
}
#pickup .listitem_box{
	background-color: #fff;
}
.listitem_box h4{
	font-size: 16px !important;
	color: #333333;
	margin: 0;
	padding: 0;
	margin-bottom: 0px;line-height: 1.4;
}
.listitem_box_text{
	padding: 10px;
}
.listitem_box .postdate{
	font-size: 14px;
	color: #808080;
}
.listitem_box_img{
	width: 100%;
	display:block;
	position: relative;
}
.listitem_box_img_img{
	width: 100%;
	z-index: 1;
	padding-top: calc(56.25% - 2px);
	background-color: #fff;
	background-position: center;
	background-size: cover;
	position: relative;
	display: block;
}
.cat_list{
	display: flex;
	gap:10px;
	position: absolute;
	flex-wrap: wrap;
	top: 5px;
	left: 5px;
	list-style: none;
	padding: 0;
	z-index: 5;
}
.cat_list > li{
}
.cat_list > li a{
	color: #fff !important;
	font-size: 14px !important;
	display: block;
	text-align: center;
	padding:0 0.5em;
	background-color: #0071BC;
    line-height: 2 !important;
    border-radius:  5px;
}

.tag_list{
	display: flex;
	gap:20px;
	flex-wrap: wrap;
	padding: 0;
}
.tag_list > li{
	color: rgba(0,62,143,1) !important;
	font-size: 16px !important;
	display: block;
	text-align: center;
}


.publications_list{
	display: flex;
	flex-wrap: wrap;
	gap:15px;
	list-style: none;
	padding: 0;
	margin-bottom: 40px;
}
.publications_list_sp{
	margin-bottom: 0px;
}
.postdate{
	font-size: 12px;
	color: #999999;
}
.publications_list h4{
	margin: auto;
	padding: 0;
	font-size: 14px;
	color: #333333;
}
.publications_list .listitem_box_img{
	width: 100%;
	display:block;
	padding-top: 145%;
	background-position: center;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	margin-bottom: 10px;
}
.publications_list .listitem_box_text{
	padding: 0;
}
.publications_list .cat_list{
	position: relative;
	margin-bottom: 10px;
}
.publications_list > li{
	width: calc(20% - 15px * 4 / 5);
}

#info_service{
	background-color: #0071bc;
	padding: 60px 30px;
}

#info_service p{
	color: #fff;
}
#join_info{
	background-color: #29abe2;
	padding: 60px 30px;
}
#join_info p{
	color: #fff;
}
#join_info .btn_w{
	margin-top: 20px;
}
#join_info .btn_w.pc_only{
	justify-content: flex-start;
}
#sns{
	background-size: cover;
	background-position: center;
	background-image: url("../images/top/top_img_03.png");
	display: flex;
	align-items: flex-end;
}
#for_medical_personnel{
	background-size: cover;
	background-position: center;
	background-image: url("../images/top/top_img_04.png");
	display: flex;
	align-items: flex-start;
}
.two_col{
	display: flex;
	width: 100%;
}
.two_col > section{
	width: 50%;
	display: flex;
	padding: 30px;
	box-sizing: border-box;
	flex-direction: column;
	align-items: center;
}
.two_col > section h3{
	margin-bottom: 30px;
	color: #fff; 
}
.two_col > section > div{
	align-items: center;
}
.two_col_innerbox{
	max-width: 570px;
	display: flex;
    box-sizing: border-box;
    flex-direction: column;
    align-items: center;
	height: 100%;
    width: 100%;
}
.sns_icons{
	display: flex;
	justify-content: space-between;
	max-width: 380px;	
	margin: auto;
	width: 70%;
}
.sns_icons > a{
	display: block;
	width: 27%;
}

.for_medical_banner{
	display: flex;
	justify-content: space-between;
	margin: auto;
	max-width: 560px;
	gap:30px;
	flex-wrap: wrap;
}
.for_medical_banner > a{
	display: block;
	width: calc(50% - 15px);
}
.for_medical_banner > a img{
	display: block;
	width: 100%;
}


@media (max-width: 1100px) {
	

	.info_btns{		
        max-width: 800px;
    margin: auto;
		margin-bottom: 40px;
		gap: 20px;
		column-gap: 0;
	}
	.info_btns li:nth-child(4){
    border-left: solid 1px #b3b3b3;
	}
}
@media (max-width: 700px) {
	.info_btns li{
    width: 12em;
    font-size: min(calc((1vw - 0.4px) * 2.75), 16px) !important;
	}
}
@media (max-width: 500px) {
	/* .info_btns li{
        width: 50%;
    font-size: min(3.5vw, 16px) !important;
	}
	.info_btns li:nth-child(4){
    border-left: 0;
	}
	.info_btns li:nth-child(3),
	.info_btns li:nth-child(5){
    border-left: solid 1px #b3b3b3;
	} */
}
@media (max-width: 1000px) {
	.two_col {
    display: flex;
    width: 100%;
    flex-direction: column;	
	}
.two_col > section {
    width: 100%;
	}
	#for_medical_personnel,
	#sns{
		align-items: center;
	}

	.info_two_col{
		flex-wrap: wrap;
	}
	.join_two_col{
		flex-wrap: wrap;
	}
	.publications_list{
		flex-wrap: wrap;
	}
	.publications_list li:nth-child(5){
		display: none;
	}
.publications_list > li {
	width: calc(50% - 15px * 1 / 2);
	}
	
	
.four_col > li {
    width: calc(50% - 30px * 1 / 2);
}
.four_col > li {
    width: calc(50% - 30px * 1 / 2);
}




}
@media (min-width: 701px) {
	.sp_only{
		display: none;
	}
}
@media (max-width: 700px) {
	.pc_only{
		display: none;
	}	
	p{
		font-size: 14px;
	}
		
#publications h3, #information h3 {
    gap: 15px;
    margin-bottom: 30px;
    font-size: 20px !important;
	}
	
	#join_info h3, #info_service h3,
	.two_col > section h3 {
    font-size: 20px !important;
	}
	#top_slider{
		padding: 0 30px;
    padding-bottom: 30px;
	}
#pickup{
	padding:30px 20px;
	padding-bottom: 40px;
}
	#pickup	.bx-viewport{
        overflow: inherit !important;
	}
#information{
	padding: 20px; 
	padding-top: 40px;
}
	#join_info,
#info_service,
#publications{
	padding: 40px 20px;
}
#pickup h3 {
	margin-bottom: 30px;
	}
	.pickup_post_list.sp_only{
	    padding: 0 10px;
	}
	.publications_list_sp{
	    padding: 0 30px;
        margin-bottom: 30px;
	}
	.two_col > section{
	padding:30px 20px;
	}
	.info_two_col .left{
		width: 100%;
	}
	
	.three_col{
		flex-direction: column;
	}
	
.three_col > div {
	width: 100%;
	border: none;
	border-bottom: solid 1px #fff;
	padding: 20px 0;
	}
	.three_col{
	border-top: solid 1px #fff;
	border-left: none;
	}
	
    .four_col > li {
        width: 100%;;
    }
.for_medical_banner {
	gap: 20px;
	}
	.for_medical_banner > a{
    width: calc(50% - 10px);
		
	}
.listitem_box h4,
	.tag_list > li {
    font-size: 14px !important;
	line-height: 1.4;
	}

	.sp_change .listitem_box:nth-child(5),
	.sp_change .listitem_box:nth-child(6),
	.sp_change .listitem_box:nth-child(7),
	.sp_change .listitem_box:nth-child(8){
		display: none;
	}
	.sp_change .listitem_box > a,
	.sp_change .listitem_box .listitem_box_inner{
		display: flex;
        padding: 10px;
        align-items: flex-start;
	}
	.sp_change  .listitem_box_text{
		padding: 0;
		padding-left: 10px;
	}
	.sp_change .listitem_box_img{
    padding-top: 0%;
    width: 30%;
    flex-shrink: 0;
		position: relative;
	}
	.sp_change .listitem_box_img_img{
		width: 100%;
		padding-top: 100%;
	}
	.sp_change .listitem_box_text .cat_list{
		position: relative;
    gap: 5px;
		left: 0;
		top: 0;
	}
	.sp_change .listitem_post_meta_sp{
		display: flex;
		justify-content: space-between;
		gap:10px;
		margin-bottom: 10px;
	}
	.sp_change .cat_list > li,
	.sp_change .cat_list > li a{
	font-size: 10px !important;
	}
	
 .sp_change .listitem_box .postdate {
	font-size: 10px;
	 line-height: 1;
	 flex-shrink: 0;
	}
}
