@charset "utf-8";


/* Base Styles
–––––––––––––––––––––––––––––––––––––––––––––––––– */
/* NOTE
html is set to 62.5% so that all the REM measurements throughout Skeleton
are based on 10px sizing. So basically 1.5rem = 15px :) */
html {
    font-size: 62.5%; }

/* レスポンシブ */
@media (max-width: 575px){
    html {
        font-size: 62.5%; }
}


body {
    font-size: 1.6rem;
    line-height: 1.6;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-style: normal;
    color: #3c3c3c;
}

p{
    font-size: 1.6rem;
    line-height: 2.5rem;
    margin-top: 0;
    font-weight: 500;
}

img{
    max-width: 100%;
}

.pc {display: block !important;}
.sp {display: none !important;}
@media only screen and (max-width: 768px) {
.pc {display: none !important;}
.sp {display: block !important;}
}









/* ハンバーガーメニュー
–––––––––––––––––––––––––––––––––––––––––––––––––– */
#g-nav {
  position: fixed;
  z-index: 999;
  top: 0;
  right: -120%;
  width: 50%;
  height: 100vh;
  background: rgba(255, 255, 255, 1.0);
  transition: all 0.4s;
}
#g-nav.panelactive {
  right: 0;
}
#g-nav.panelactive #g-nav-list {
  position: fixed;
  z-index: 999;
  width: 50%;
  height: 100vh;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
/*ナビゲーション*/
#g-nav ul {
  position: absolute;
  z-index: 999;
  top: 50%;
  left: 48%;
  transform: translate(-50%, -50%);
  width: 100%;
}
#g-nav li {
  list-style: none;
  text-align: center;
  width: 400px;
  margin: 0 auto;
}
#g-nav li a {
  font-size: 2rem;
  color: #7099a3;
  text-decoration: none;
  padding: 10px 0;
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.01rem;
  line-height: 1.35;
  font-weight: bold;
  text-align: left;
}

/*========= ボタンのためのCSS ===============*/
.openbtn1 {
  position: fixed;
  z-index: 9999;
  right: 14px;
  top: 10px;
  width: 60px;
  height: 60px;
  cursor: pointer;
  background: rgb(255,255,255,0.3);
  border-radius: 50%;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.25);
}
.openbtn1 span {
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 15px;
  background: #7099a3;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.openbtn1 span:nth-of-type(1) {
  top: 20px;
}
.openbtn1 span:nth-of-type(2) {
  top: 30px;
}
.openbtn1 span:nth-of-type(3) {
  top: 40px;
}
.openbtn1.active span:nth-of-type(1) {
  top: 30px;
  left: 15px;
  background: #7099a3;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.openbtn1.active span:nth-of-type(2) {
  top: 30px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg);
}
.openbtn1.active span:nth-of-type(3) {
  top: 30px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  transform: rotate(45deg);
}

small {
  display: inline-block;
  text-align: center;
}

#header {
  width: 100%;
  background: #333;
  color: #fff;
  text-align: center;
  padding: 20px;
}

















.top-heading{
  padding: 100px 0;
  border-bottom: solid 1px #bad9e0;
  background-image: url(../img/back02.jpg);
  background-position: right;
  background-size: cover;
}

.top-heading h1{
  font-size: 9.5rem;
  text-align: left;
  font-weight: 900;
  letter-spacing: 0.4rem;
  font-style: normal;
  display: inline-block;
  background: linear-gradient(53deg, rgba(56,72,77,1) 0%, rgba(58,82,89,1) 53%, rgba(112,153,163,1) 100%);
  background: -webkit-linear-gradient(53deg, rgba(56,72,77,1) 0%, rgba(58,82,89,1) 53%, rgba(112,153,163,1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.top-heading h4{
  font-size: 2.3rem;
  padding: 30px 0;
  letter-spacing: 0.2rem;
}


.top-copy{
  text-align: center;
  margin-bottom: 60px;
  padding-top: 100px;
}


.top-copy p{
  text-align: center;
  font-size: 4rem;
  letter-spacing: 0.2rem;
  font-weight: 600;
  background: rgb(56,72,77);
background: linear-gradient(53deg, rgba(56,72,77,1) 0%, rgba(58,82,89,1) 53%, rgba(112,153,163,1) 100%);
  display: inline-block;
  margin: 0 auto;
  color: #fff;
  padding: 15px 50px;
}



@media (min-width: 1200px){
.top-heading .container ,
.sec_card_list .container{
  max-width: 80vw;
}
}


.sec_card_list .container{
  background: rgb(255, 255, 255, 0.5);
  border: solid #bad9e0;
  border-width: 0 1px;
}


.info_card{
  padding-bottom: 100px;
}

.info_card figure{
  overflow: hidden;
}

.info_card img{
  width: 100%;
  height: 450px;
  object-fit: cover;
  object-position: top;
}

.info_figure02 img{
  object-position: right;
}

.info_figure11 img{
  object-position: left;
}


.info_card a{
  color: #3c3c3c;
  text-decoration: none;
  overflow:hidden;
	display:block;
}

.info_card h3{
  font-size: 2.3rem;
  position: relative;
  letter-spacing: 0.2rem;
  line-height: 3rem;
  padding: 40px 10px 10px 20px;
  background-repeat: no-repeat;
  background-size: 5px 100%;
  background-position: left;
  top: -20px;
  left: 20px;
  transition: 0.3s;
}

.info_card h3 span{
  font-size: 1.7rem;
  transition: 0.3s;
}

.doboku_h3{background-image: linear-gradient(180deg, #F38321 0 35%, #3c3c3c 35%);}
.kentiku_h3{background-image: linear-gradient(180deg, #DEA426 0 35%, #3c3c3c 35%);}
.kikai_h3{background-image: linear-gradient(180deg, #84BA41 0 35%, #3c3c3c 35%);}
.denki_h3{background-image: linear-gradient(180deg, #299F85 0 35%, #3c3c3c 35%);}
.seimei_h3{background-image: linear-gradient(180deg, #26499D 0 35%, #3c3c3c 35%);}
.joho_h3{background-image: linear-gradient(180deg, #723C92 0 35%, #3c3c3c 35%);}


.info_card a:hover .doboku_h3 span{color: #be702a !important;}
.info_card a:hover .doboku_h3 {color: #ffb16c !important;}

.info_card a:hover .kentiku_h3 span{color: #7a622c !important;}
.info_card a:hover .kentiku_h3 {color: #DEA426 !important;}

.info_card a:hover .kikai_h3 span{color: #698b3e !important;}
.info_card a:hover .kikai_h3 {color: #84BA41 !important;}

.info_card a:hover .denki_h3 span{color: #2a7665 !important;}
.info_card a:hover .denki_h3 {color: #299F85 !important;}

.info_card a:hover .seimei_h3 span{color: #283e74 !important;}
.info_card a:hover .seimei_h3 {color: #26499D !important;}

.info_card a:hover .joho_h3 span{color: #59376e !important;}
.info_card a:hover .joho_h3 {color: #723C92 !important;}


.info_card a img:hover{
	transform:scale(1.1);
	transition:0.7s;
}


.archive-link ul{
  padding:0;
  list-style: none;
  display:flex;
  margin: 0;
}

.archive-link ul li{
  width: 50%;
}

.archive-link ul li {
    border: 1px solid #bad9e0;
}


.archive-link ul li a{
  color: #3c3c3c;
  display: block;
  width: 100%;
  padding: 30px 0;
  font-weight: 500;
  font-size: 2rem;
  text-decoration: none;
	transition:0.3s;
}

.archive-link ul li a:hover{
  color: #fff;
  background: #bad9e0;
}


@media (max-width: 1499px) {
  .info_card img {
    height: 350px;
  }
  
}


















main {
  background-image: url('../img/back01.jpg');
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}






#main-img{
  padding-right: 30px !important;
}

#main-img img{
  border-radius: 0 5px 5px 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}





#sec0 h1 {
  font-weight: 900;
  font-size: 6rem;
  margin-bottom: 100px;
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  display: inline-block;
  background: linear-gradient(90deg, #38484d, #626f73 75%, #7099a3);
  background: -webkit-linear-gradient(0deg, #38484d, #626f73 75%, #7099a3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}


#sec0 .row,
#sec01 .row{
  justify-content: flex-end;
}

#sec0 .info{
  color: #3c3c3c;
  font-weight: 600;
}

#sec0 .name{
  font-size: 3rem;
  font-weight: 700;
}

#sec0 .name span{
  font-size: 2rem;
  position: relative;
  bottom: -1px;
}

#sec0 .position{
  font-weight: 800;
  font-size: 3.2rem;
  line-height: 4.5rem;
  letter-spacing: 0.2rem;
  color: #3c3c3c;
  margin-top: 10px;
  padding-top: 15px;
}

.sec_doboku .position{border-top: solid 2px #F38321;}
.sec_kentiku .position{border-top: solid 2px #DEA426;}
.sec_kikai .position{border-top: solid 2px #84BA41;}
.sec_denki .position{border-top: solid 2px #299F85;}
.sec_seimei .position{border-top: solid 2px #26499D;}
.sec_joho .position{border-top: solid 2px #723C92;}


#sec0 .intro-heading{
  margin-bottom: 150px;
}

#sec0 .affiliation{
  line-height: 3.5rem;
  margin-bottom: 4px;
}

#sec0 .affiliation span{
  color: #fff;
  padding: 4px 7px;
  border-radius: 2px;
}

.sec_doboku .affiliation span{background: #F38321;}
.sec_kentiku .affiliation span{background: #DEA426;}
.sec_kikai .affiliation span{background: #84BA41;}
.sec_denki .affiliation span{background: #299F85;}
.sec_seimei .affiliation span{background: #26499D;}
.sec_joho .affiliation span{background: #723C92;}



#sec0 .alma_mater{
  display: inline-block;
  background: #777;
  color: #fff;
  padding: 4px 7px;
  border-radius: 2px;
}


#sec01 .article{
  margin-bottom: 135px;
}

#sec01 h3{
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 4rem;
  color: #3c3c3c;
  margin-bottom: 10px;
  display: inline-block;
  background: linear-gradient(90deg, #38484d, #626f73 75%, #7099a3);
  background: -webkit-linear-gradient(0deg, #38484d, #626f73 75%, #7099a3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

#sec01 p{
  font-size: 1.7rem;
  text-align: justify;
  padding-top: 10px;
  line-height: 2.7rem;
  background-image: linear-gradient(90deg, #84BA41 0 20%, #bad9e0 20%);
  background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: top;
}


#sec01.sec_doboku p{background-image: linear-gradient(90deg, #F38321 0 20%, #bad9e0 20%);}
#sec01.sec_kentiku p{background-image: linear-gradient(90deg, #DEA426 0 20%, #bad9e0 20%);}
#sec01.sec_kikai p{background-image: linear-gradient(90deg, #84BA41 0 20%, #bad9e0 20%);}
#sec01.sec_denki p{background-image: linear-gradient(90deg, #299F85 0 20%, #bad9e0 20%);}
#sec01.sec_seimei p{background-image: linear-gradient(90deg, #26499D 0 20%, #bad9e0 20%);}
#sec01.sec_joho p{background-image: linear-gradient(90deg, #723C92 0 20%, #bad9e0 20%);}



.table-area th,
.table-area td{
  vertical-align: top;
  font-size: 1.6rem;
  letter-spacing: 0.2rem;
  line-height: 2.6rem;
}


.table-area th.th2ch{width: 50px;}
.table-area th.th4ch{width: 80px;}
.table-area th.th6ch{width: 110px;}

.table-area table{
  width: 100%;
}

#sec01 .table-area p{
  background-size: 0;
}

#sec01 .table-area .lead_p{
  color: #3c3c3c;
  font-weight: 800;
  font-size: 2.3rem;
  padding-top: 55px;
  margin-bottom: 15px;
  letter-spacing: 0.3rem;
  display: flex;
  align-items: center;
}

#sec01 .table-area .lead_p:after {
  content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #3c3c3c;
}

#sec01 .table-area .lead_p:after {
  margin-left: 1rem;
}


#sec01 .table-area .notes{
  font-size: 1.5rem;
  color: #7099a3;
}






.before-after_link{
  border-top: solid 1px #BAD9E1;
  margin-top: 30px;
}

.link-btn{
  display: flex;
  justify-content: center;
  gap: 20px;
  padding-top: 50px;
}

.link-btn-block{
  width: 100px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.link-btn-block a{
  color:#444c55;
  font-size: 2.3rem;
}






/*左と右を囲う全体のエリア*/
#wrapper{
	position: relative;/*position stickyの基点にするため relativeをかける*/
	display: flex;/*左エリア、右エリア横並び指定*/
	flex-wrap: wrap;/*ボックスの折り返し可*/
}

/*左エリア*/
#fixed-area{
  position: -webkit-sticky;/*Safari用*/
  position: sticky;
  top:0;
	width: 50%;
	height: 100vh;
  padding-top: 10rem;
  border-right: solid 1px #bad9e0;
  background: rgb(255, 255, 255, 0.5);
}

/*右エリア*/
#container{
	width:50%;
  padding: 0 5%;
  padding-top: 10rem;
  background: rgb(255, 255, 255, 1.0);
}

/*＝＝＝＝＝＝＝＝＝＝＝7991px以下の見え方＝＝＝＝＝＝＝＝＝＝＝＝＝*/

@media screen and (max-width:991px){
#wrapper{
display: block;/*display:flex;を解除*/
}
#fixed-area{
position:relative!important;/*position stickyを解除*/
width:100%;/*横幅を100%にして1列に見せる*/
height: 40vh;/*縦幅を100vh⇒40vh　※任意の高さに設定可能*/
}
#container{
width:100%;/*横幅を100%にして1列に見せる*/
}
}




.footer-2024{
  background: #7099a3;
  color: #fff;
}









/*矢印が右に移動する*/
.btnarrow4{
  position: relative;
  display: inline-block;
  padding-top: 15px;
  padding-right: 35px;
  color: #7099a3;
  text-decoration: none;
  outline: none;
}

/*矢印と下線の形状*/
.btnarrow4::before{
  content: '';
position: absolute;
  bottom:-8px;
  left:45%;
  width: 55%;
  height: 1px;
  background:#7099a3;
  transition: all .3s;
}

.btnarrow4::after{
  content: '';
  position: absolute;
  bottom:-3px;
  right:0;
  width: 15px;
  height:1px;
  background:#7099a3;
  transform: rotate(35deg);
  transition: all .3s;
}

/*hoverした際の移動*/
.btnarrow4:hover{
  text-decoration: none;
  color: #7099a3b4;
}

.btnarrow4:hover::before{
  left:50%;
}

.btnarrow4:hover::after{
  right:-5%;
}








/*＝＝＝＝＝＝＝＝＝＝＝個別ページレスポンシブ＝＝＝＝＝＝＝＝＝＝＝＝＝*/

/* レスポンシブ */


.pc-tab{display: block !important;}
.tab-sp{display: none !important;}


@media (max-width: 1699px) {

.br1700{display: none;}

#sec0 h1 {
  font-size: 6rem;
}
}

@media (max-width: 1199px) {
  
/* 個別ページ */
#fixed-area{width: 40%;}
#container {width: 60%;}
#sec0 h1 {font-size: 5rem;}
#main-img img{height:50vh;}
}

@media (max-width: 991px) {
  
/* 個別ページ */
.pc-tab{display: none !important;}
.tab-sp{display: block !important;}

#fixed-area{
  width: 100%;
  height: 100%;
  background: rgb(255, 255, 255, 1);
  padding-bottom: 5%;
  border-right: none;
  border-bottom: solid 1px #bad9e0;}

#container {width: 100%;background: rgb(255, 255, 255, 0.3);}
.link-btn-block {width: 100px;}

#main-img img {height: 100%;}

/* 一覧 */
  .info_card h3 span {
    font-size: 1.6rem;
    letter-spacing: 0rem;
    position: relative;
    top: -10px;
  }

.archive-link ul li a {
  padding: 35px 25px;
}

}




@media (max-width: 767px) {

  #g-nav , #g-nav.panelactive #g-nav-list , #g-nav li{width: 100%;}

/* 個別ページ */
#container {padding-top: 5%;}
  #sec0 h1 {font-size: 4rem;line-height: 6rem;}
  #sec0 .position{font-size: 2.2rem;line-height: 2.9rem;letter-spacing: 0;}
  #sec0 .intro-heading{margin-bottom: 80px;}
  #sec01 .article {margin-bottom: 75px;}
  #sec01 h3 {font-size: 2.1rem;line-height: 3rem;}
  #sec01 p {font-size: 1.5rem;line-height: 2.3rem;}

/* 一覧 */
.top-heading h1 {font-size: 7.5rem;}
.info_card img {height: 240px;}
.info_card {padding-bottom: 20px;}
.info_card h3{line-height: 1.8rem;width: 90%;}
.archive-link ul li {width: 100%;padding: 5px;}
.archive-link ul li+ li {border-top: 1px solid #bad9e0;}

}

@media (max-width: 575px) {

/* 個別ページ */
#sec0 h1 {font-size: 3rem;margin-bottom: 45px;line-height: 4.5rem;}


/* 一覧 */
  .top-heading {padding: 40px 0 10px;}
  .top-heading h1 {font-size: 4.7rem;}
  .top-heading h4 {font-size: 1.9rem;line-height: 3rem;}

  .top-copy p{font-size: 2.5rem;padding: 15px 15px;}
  .info_card h3{font-size: 1.8rem;letter-spacing: 0;left: 10px;height: 140px;}
  .info_card h3 span{font-size: 1.5rem;top: -5px;}


  .info_figure02 img{
    object-position: 80%;
  }
  
  .info_figure04 img{
    object-position: 80%;
  }
  
  .info_figure05 img{
    object-position: 75%;
  }
  
  .info_figure06 img{
    object-position: 80%;
  }
  
  .info_figure07 img{
    object-position: 30%;
}

  .info_figure08 img{
    object-position: 80%;
  }
  
  .info_figure09 img{
    object-position: 80%;
  }
  
  .info_figure11 img{
    object-position: 10%;
  }
  
  .info_figure12 img{
    object-position: 80%;
  }

}