@charset "utf-8";

@-ms-viewport {
  width: device-width;
}

@viewport {
  width: device-width;
}


@media screen and (max-width:840px){

* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size:3.7vw
}
	
.pc{display:none!important;}
.sp{display:block!important;}	


/*header
----------------------------------------------------*/
header{
    height: auto;
}

header.top{
    height: auto;
}

header #headIn{
    height: 60px;
}

header h1{
	float:none;
	width: auto;
	height: 60px;
	margin:0 0 0 3%;
	display: block;
}

header h1 img{
	width: auto;
	max-width: none;
	height: 60px;
	margin: 0 auto 0 0;
}

header.fixnavi h1{
	margin:0 0 0 3%;
}


/*navigation
----------------------------------------------------*/
header #headIn{
	width: 100%;
	display:flex;
    justify-content: space-between;
}

.scroll-lock #headIn{
	background:#1D3574;
}

.megamenu {
    width: 100%;
    margin-right: 0;
}

.megamenu ol {
	width:94%;
	margin: 4vw auto;
	padding: 0;
	display: block;
}

.megamenu ol li{
	margin: 0;
	padding: 2vw;
	border-bottom: 1px solid #CCC;
}

.megamenu ol li a{
    padding: 5px 0;
    color: #FFF;
	text-align: left;
	display: block;
}

.megamenu ol li.btn_contact{
    width: 100%;
	padding: 6vw 0 0 0;
	border-bottom: 0;
    flex:auto;
}

.megamenu ol li.btn_contact a{
    border: 1px solid #FFF;
	text-align: center;
}

.megamenu div ul li{
	padding: 0 4vw;
	border-bottom: 0;
}


/*sp button
-------------------------------------------------*/
#triggerBox{
    position: fixed;
    top: 2vw;
    right: 2vw;
	width: 45px;
	height: 45px;
    z-index: 10001;
}
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 100%;
	height: 100%;
	/*background-color: #324C9C;*/
	display: block;
}
.menu-trigger span {
    position: absolute;
    left: 13px;
    width: 20px;
    height: 2px;
    background-color: #FFF;
}
.menu-trigger span:nth-of-type(1) {
    top: 13px;
}
.menu-trigger span:nth-of-type(2) {
	top: 20px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 16px;
}
.menu-trigger.active span:nth-of-type(1) {
    top: 15px;
	-webkit-transform: translateY(4px) rotate(-315deg);
	transform: translateY(4px) rotate(-315deg);
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	bottom: 14px;
	-webkit-transform: translateY(-10px) rotate(315deg);
	transform: translateY(-10px) rotate(315deg);
}







/*mv
----------------------------------------------------*/
header .splide__slide{
    height: 60vh;
}

header .splide__slide h2{
	position: absolute;
    bottom:10vw;
	left:5%;
	line-height: 1.4;
	font-size: 6.0vw;
}

header .splide__slide h2 .blue1{
	font-size: 1.5em;
}

header .splide__slide h2 .blue2{
	font-size: 6.0vw;
	padding-left: 0;
}

header .splide__slide img{
	width: 100vw;
    height: 60vh;
    object-fit: cover;
	object-position: 70% top;
}

header .mask{
    height: 60vh;
}


.splide__arrow {
    width: 2em!important;
    height: 2em!important;
}

.splide__arrow svg {
    height: 2em!important;
    width: 2em!important;
}

.mv_ttl{
    height: 60vw;
}

.mv_ttl h2{
	bottom: 3vw;
	left:3%;
	line-height: 1.4;
	font-size: 5vw;
}

.mv_ttl h2 span{
	font-size: 10vw;
	display: block;
}

.mv_ttl .mask,
.union .mv_ttl .mask{
    height: 60vw;
}


/*common
----------------------------------------------------*/
section{
	padding: 12vw 0;
}

.contents{
	width: 90%;
}

.article_inner{
	padding: 0 0 20vw 0;
}

.article_inner:before{
	display: none;
}

.article_inner .contents{
	display: block;
}

.main{
	margin-bottom: 12vw;
}

.side{
	width: 100vw;
	margin-inline: calc(50% - 50vw);
	padding: 8vw 5% 0 5%;
	border-top: 1px solid #CCC;
	border-left: 0;
}

.path{
	padding: 6vw 3% 10vw 3%;
}

.path ul li,
.path ul li a{
	font-size:3.0vw;
}

.path ul li a:after,
.path ul li span:after{
	font-size:3.0vw;
}


/*top news
----------------------------------------------------*/
.sec_top_news .contents{
	width: 90%;
	display: block;
}

.sec_top_news .contents div{
	margin-bottom: 8vw;
}

.sec_top_news .contents h2{
	font-size: 12vw;
}

.sec_top_news .contents h2 span{
	font-size: 5vw;
}

.sec_top_news .contents dl{
	margin-bottom: 3vw;
	padding-bottom: 3vw;
}


/*top about
----------------------------------------------------*/
.sec_top_about{
    padding-top: 0;
}

.sec_top_about .contents{
    padding: 0;
}

.sec_top_about .ph{
    position: relative;
    top:0;
    width: 100%;
    height: 60vw;
	margin-bottom: 12vw;
}

.sec_top_about .contents h2{
    margin-bottom: 6vw;
	font-size: 20vw;
}

.sec_top_about .contents h2 span{
	font-size: 5vw;
}


/*top field
----------------------------------------------------*/
.sec_top_field{
	padding-top: 60vw;
}

.sec_top_field .ph{
	height: 70vw;
}

.sec_top_field .contents{
	padding: 6vw 0;
}

.sec_top_field .box_ttl{
	margin-bottom: 12vw;
	display: block;
}

.sec_top_field .box_ttl h2{
	padding: 0 6vw;
	font-size: 20vw;
}

.sec_top_field .box_ttl h2 span{
	font-size: 5vw;
}

.sec_top_field .box_ttl p{
	padding: 4vw 6vw 0 6vw;
}

.sec_top_field .box_field{
	display: grid;
	grid-template-columns: 1fr;
	grid-gap: 8vw;
}

.sec_top_field .box_field dl dt{
	padding: 3vw 0;
	font-size: 6vw;
}

.sec_top_field .box_field dl dd{
	padding: 6vw;
}

.sec_top_field .box_field dl dd p{
	margin-bottom: 6vw;
}

.sec_top_field .box_field dl dd ul{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap: 0 20px;
}

.sec_top_field .box_field dl dd ul li:nth-of-type(1){
	background: url("../img/top/icon_research.png") no-repeat center top 4vw / auto 8vw;
}

.sec_top_field .box_field dl dd ul li:nth-of-type(2){
	background: url("../img/top/icon_examine.png") no-repeat center top 4vw / auto 8vw;
}

.sec_top_field .box_field dl dd ul li a{
	padding: 14vw 0 10vw 0;
	background: url("../img/icon_link2.png") no-repeat center bottom 4vw / 4vw;
}


/*top recruit
----------------------------------------------------*/
.sec_top_recruit{
	padding-top: 30vw;
}

.sec_top_recruit .ph{
	height: 40vw;
}

.sec_top_recruit .contents{
	margin: 0 auto;
	padding: 6vw 0;
	grid-template-columns: 1fr;
	grid-gap: 4vw;
}

.sec_top_recruit h2{
	padding-top: 0;
	font-size: 20vw;
	text-align: center;
}

.sec_top_recruit h2 span{
	font-size: 5vw;
}

.sec_top_recruit ul li:nth-of-type(1){background: url("../img/top/icon_recruit01.png") no-repeat left center / 6vw;}
.sec_top_recruit ul li:nth-of-type(2){background: url("../img/top/icon_recruit02.png") no-repeat left center / 6vw;}
.sec_top_recruit ul li:nth-of-type(3){background: url("../img/top/icon_recruit03.png") no-repeat left center / 6vw;}

.sec_top_recruit ul li a{
	padding: 4vw 0 4vw 9vw;
	background: url("../img/top/icon_recruit_link.png") no-repeat right center / 8vw;
	font-size: 5vw;
}


/*top bana
----------------------------------------------------*/
.sec_top_bana .contents ul{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap:6vw;
}

.sec_top_bana ul li{
	padding-top: 20vw;
}

.sec_top_bana ul li:nth-of-type(1){background: #FFF url("../img/top/ph_bana01.jpg") no-repeat center top -4vw / 120%;}
.sec_top_bana ul li:nth-of-type(2){background: #FFF url("../img/top/ph_bana02.jpg") no-repeat center top -4vw / 120%;}
.sec_top_bana ul li:nth-of-type(3){background: #FFF url("../img/top/ph_bana03.jpg") no-repeat center top -4vw / 120%;}
.sec_top_bana ul li:nth-of-type(4){background: #FFF url("../img/top/ph_bana04.jpg") no-repeat center top -4vw / 120%;}

.sec_top_bana ul li a{
	padding: 2vw 0 14vw 0;
	background: url("../img/icon_link2.png") no-repeat bottom 6vw center / 4vw;
}

.sec_top_bana ul li a span{
	font-size: 3.0vw;
}


/*main
----------------------------------------------------*/
.main h2,
.union .main h2{
	margin-bottom: 12vw;
	font-size: 8vw;
}

.main h3,
.union .main h3{
	margin: 16vw auto 6vw auto;
	padding-bottom: 3vw;
	font-size: 5vw;
}

.main h4,
.union .main h4{
	font-size: 4vw;
}

.main .f_right,
.main .f_left{
	float: none;
	width: 100%;
	margin: 0 0 6vw 0;
}

.main .kakomi,
.union .main .kakomi{
	padding: 6vw;
}

.main .kakomi_attention{
	padding: 6vw;
}

.main .btn_large,
.union .main .btn_large{
	padding: 3vw 2.0em;
	border-radius: 2em;
	font-size: 3.7vw;
}


/*side
----------------------------------------------------*/
.side h2,
.union .side h2{
	margin-bottom: 8vw;
	font-size: 5vw;
}

.side h2:before,
.union .side h2:before{
	display: none;
}

.side ul li a{
	font-size: 3.4vw;
}


/*about
----------------------------------------------------*/
.box_about_mission{
	margin-bottom: 16vw;
	padding: 43vw 0 0 0;
	background: url("../img/about/ph_mission-vision01.jpg") no-repeat left top / 95%;
}

.box_about_vision{
	padding: 43vw 0 0 0;
	background: url("../img/about/ph_mission-vision02.jpg") no-repeat right top / 95%;
}

.box_about_mission div,
.box_about_vision div{
	width: 95%;
	margin: 0 0 0 auto;
	padding: 6vw;
}

.box_about_history dl,
.box_about_history dl:nth-of-type(1){
	padding-bottom: 8vw;
}

.box_about_history dl:before{
	top:6vw;
}

.box_about_history dl dt{
	margin-left: 6vw;
	padding-bottom: 2vw;
	background: url("../img/bg_history2.png") no-repeat top 0.5em left 6.8em / 8vw;
}

.box_about_history dl dt span{
	font-size: 6vw;
}

.box_about_history dl dd{
	margin: 0 0 0 6vw;
	padding-bottom: 3em;
}

.box_about_staff h2{
	margin-top: 16vw!important;
	padding: 3vw 4vw;
	font-size: 5vw;
}

.box_about_staff .h3_staff{
	margin-bottom: 10vw;
}

.box_staff{
	margin-bottom: 10vw;
	padding-bottom: 4vw;
	display: block;
}

.box_staff img{
	margin: 2vw auto 3vw auto;
}

.box_staff .name{
	font-size: 6vw;
}

.box_staff .name span {
	position: relative;
	top: -4px;
	margin-left: 1.5vw;
	font-size: 3.0vw;
}

.box_staff .name span:nth-of-type(1){
	margin-left: 5vw;
}

.box_staff dl{
	margin-bottom: 6vw;
}

.box_staff dl dt{
	margin-bottom: 4vw;
	padding: 1vw 3vw;
	font-size: 4vw;
}

.box_staff.detail h2{
	padding: 6vw 0;
}

.box_staff.detail h3{
	margin-top: 8vw!important;
	font-size: 4vw;
}

.box_staff.detail ul li{
	margin-left: 4vw;
}

.box_staff.detail table th,
.box_staff.detail table td{
	display: block;
}

.box_archives{
	display: block;
}

.box_archives div{
	margin-bottom: 6vw;
	padding: 6vw 6vw 3vw 6vw;
	display: grid;
	grid-template-columns: 7em 1fr;
}

.box_archives h3{
	margin: 0 auto 0 0;
	padding-bottom: 2vw;
	font-size: 4vw;
}

.box_archives h3 span{
	font-size: 6vw;
}

.box_archives ul li{
	width: 100%;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #D9D9D9;
}

.box_archives_past{
	margin-top: 10vw;
	padding-top: 10vw;
}

.box_archives_past ul{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap: 4vw 6vw;
}

.box_archives_past ul li a{
	padding: 2vw 4vw;
	background: url("../img/icon_link4.png") no-repeat center right 4vw / 1em;
}

.box_archives_past ul li a span{
	font-size: 5vw;
}

.box_archives_detail h2{
	padding: 3vw 4vw;
	font-size: 5vw;
}

.box_archives_detail h3{
	margin-top: 6vw;
}

.box_archives_detail ol li{
	margin: 0 0 4vw 0;
	padding-bottom: 4vw;
}

#archives_choice{
	margin-bottom:8vw;
}

#archives_choice #arrow_inner{
	padding: 6vw;
}

#archives_choice #arrow_inner .box_archives div{
	padding: 4vw;
}


/*examine
----------------------------------------------------*/
.box_examine{
	margin-top: 10vw;
}

.box_examine div{
	margin-bottom: 10vw;
	padding: 6vw;
}

.box_disease_name {
	margin-bottom: 8vw;
	display: block;
	overflow: scroll;
}

.box_disease_name table{
	word-break: keep-all;
	overflow-wrap: normal;
}
  
.box_disease_name table td{
	text-align: right;
	word-break: keep-all;
}

.box_examine .ml30{
	margin-left: 0!important;
}


/*recruit
----------------------------------------------------*/
.btn_recruit{
	width: 100%;
	margin: 10vw auto;
	display: block;
}

.btn_recruit a{
	margin-bottom: 5vw;
}

.box_recruit_message.list{
	display: block;
}

.box_recruit_message.list dl{
	margin-bottom: 10vw;
	display: grid;
	grid-template-columns: 0.5fr 1fr;
	grid-gap: 6vw;	
}

.box_recruit_message dl dd p span{
	font-size: 14px;
	font-weight: normal;
	display: block;
}

.box_recruit_message.list dl dd a{
	font-size: 3.0vw;
}

.box_recruit_message.detail dl{
	margin-bottom: 4vw;
	display: grid;
	grid-template-columns: 0.5fr 1fr;
	grid-gap: 6vw;	
}

.box_recruit_message.detail dl dd h4{
	font-size: 5vw;
}


/*related
----------------------------------------------------*/
#map{
	height: 50vh;
}

.related_map{
	height: auto;
}

.related_map #hospital-list{
	height: 45vh;
	margin: 6vw 3%;
	padding: 2vw;
	border: 1px solid #D9D9D9;
	overflow: scroll;
}

.related_map .box_list_ttl{
	display: none;
}

.related_map #hospital-list .p-4{
	padding: 3vw;
}

/*ポップアップCloseボタン
-------------------------*/
.gm-style-iw{
	padding: 3vw!important;
}

.gm-style-iw-chr{
	width: 6vw!important;
	height: 6vw!important;
	top: -3vw;
	right: -3vw;
}

.gm-ui-hover-effect{
	width: 6vw!important;
	height: 6vw!important;
	border-radius: 3vw;
}

.gm-ui-hover-effect span{
	width: 4vw!important;
	height: 4vw!important;
	margin: 1vw!important;
}

/*ポップアップ枠内
-------------------------*/
.gm-style-iw h3{
	margin-bottom: 3vw;
	font-size: 3.7vw;
}

.gm-style-iw ul{
	margin-bottom: 3vw;
}

.gm-style-iw a{
	border-radius: 6vw;
}

.btn_link_hospital a{
	margin: 0 auto 4vw auto;
	display: block;
}

.btn_link_hospital{
	margin-top: 10vw;
}


/*link
----------------------------------------------------*/
.box_link h2{
	margin: 0 0 10vw 0;
	padding: 3vw 4vw;
	font-size: 5vw;
}

.box_link h3{
	margin-top: 10vw;
}


/*union
--------------------------------------------*/
.box_journal .ph_face{
	float:none;
	width:50%;
	margin:0 auto 4vw auto;
}

.gallery_navi{
	margin-bottom: 40px;
	border-bottom: 0;
	display: block;
}

.gallery_navi ul{
	margin-bottom: 0;
	border-bottom: 1px solid #0E368D;
	display: block;
}

.gallery_navi ul li a{
	border-left: 1px solid #0E368D;
}


/*footer
----------------------------------------------------*/
footer{
	padding: 8vw 0;
}

footer .contents{
	display: grid;
	grid-template-columns: 1fr;
	grid-gap: 6vw;
}

footer h2{
	width: 80%;
	margin: 0 auto 4vw auto;
}

footer .box_contact{
	margin-bottom: 0;
	padding-bottom: 6vw;
	text-align: center;
	display: grid;
	grid-template-columns: 1fr;
	grid-gap:4vw;
}

footer p{
	text-align: center;
}

footer .box_contact span{
	font-size: 6vw;
}

footer .box_contact .btn{
	width: 70%;
	margin: 0 auto;
	padding: 3vw 0;
}

footer .box_link,
footer .box_link2{
	display: none;
}

footer iframe{
	width: 100%;
	height: 60vw;
}

footer .copyright{
	width: 90%;
	margin: 0 auto;
	padding-top: 6vw;
	font-size: 2.8vw;
}


/*page top
--------------------------------------------*/
#page-top a{
	width:8vw;
	height:8vw;
}

}