@charset "UTF-8";
/*------------------------------------------------------------mainphoto*/
#mainimage {
	position: relative;
	height: calc(100vh - 199px);
  background: url("../img/index_img/bg_mainimage.jpg") center center no-repeat;
	background-size: cover;
}
#mainimage h2{
	position: absolute;
    bottom: 60px;
    left: 0;
	font-size: 28px;
	font-weight: 700;
	color: #fff;
    background: rgba(0, 162, 229, 0.70);
    padding: 24px 40px;
}

@media print, screen and (min-width:768px){
	#mainimage {
	height: calc(100vh - 117px);
}
	#mainimage h2{
		bottom: 100px;
	font-size: 46px;
		 padding: 36px 50px;
}
	#mainimage h2 .pc_none{
		display: none;
	}
}
/*------------------------------------------------------------content*/
/*bn_link*/
#bn_link{
	padding: 50px 0;
}
#bn_link .inner{
	max-width: 1720px;
	padding: 0 3%;
	margin: 0 auto;
}

#bn_link ul.link01{
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
	margin-bottom: 15px;
  & li {
    width: calc((100% - 15px) / 2);
    & a {
      position: relative;
      padding: 80px 0;
      display: block;
      text-decoration: none;
      color: #fff;
      overflow: hidden;
      &::before {
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        transition: all 0.5s;
      }
    }
  }
}

#bn_link ul.link01 li:nth-child(1) a::before{
	background: url("../img/index_img/bn_link01.jpg") center center no-repeat;
	background-size: cover;
}
#bn_link ul.link01 li:nth-child(2) a::before{
	background: url("../img/index_img/bn_link02.jpg") center center no-repeat;
	background-size: cover;
}
#bn_link ul.link01 li:nth-child(3) a::before{
	background: url("../img/index_img/bn_link03.jpg") center center no-repeat;
	background-size: cover;
}
#bn_link ul.link01 li:nth-child(4) a::before{
	background: url("../img/index_img/bn_link04.jpg") center center no-repeat;
	background-size: cover;
}
#bn_link ul li a:hover::before{
	width: 105%;
	height: 105%;
}

#bn_link ul li a .link_tx{
	font-size: 24px;
	font-weight: 700;
}

#bn_link ul li a .btn01 {
	position: absolute;
	bottom: 15px;
	right: 0;
	display: inline-block;
	width: 120px;
	font-size: 18px;
	color: #fff;
	background: linear-gradient(to right, #00a2e5 0, #7ad5ff 51%, #00a2e5 100%);
	background-size: 200% auto;
	transition: background-position .5s,box-shadow .3s,background-color .3s;
	padding: 7px 10px;
	box-sizing: border-box;
}
#bn_link ul li a:hover .btn01 {
	background-position: right center;
}
@media print, screen and (min-width:768px){
	#bn_link{
	padding: 100px 0;
}
	#bn_link .inner{
	padding: 0 7%;
}
	#bn_link ul{
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
#bn_link ul.link01{
  justify-content: space-between;
  gap: 0;
	margin-bottom: 30px;
  & li {
    width: 23%;
    & a {
      padding: 170px 0;
    }
  }
}
	#bn_link ul li a .link_tx{
	font-size: 32px;
}
	#bn_link ul li a .btn01 {
	bottom:30px;
}
}

/*greeting*/
#greeting {
  padding: 0 0 50px
}
#greeting .inner{
	max-width: 1720px;
	padding: 0 3%;
	margin: 0 auto;
}
#greeting .flex_box {
  display: flex;
  justify-content: space-between;
	flex-wrap: wrap;
}
#greeting .tx_box {
  text-align: left;
	z-index: 1;
  width: 85%;
  background: rgba(255, 255, 255, 0.8);
  padding: 30px 20px;
	margin: 60px 0;
}
#greeting .tx_box .sp_none{
	display: none;
}
#greeting figure {
  width: 85%;
  background: url("../img/index_img/ph_greeting.jpg") center center no-repeat;
  background-size: cover;
  margin-left: -70%;
}
@media print, screen and (min-width:768px) {
  #greeting {
    padding: 0 0 100px;
  }
	#greeting .inner{
	padding: 0 7%;
}
	#greeting .flex_box {
		justify-content: center;
	flex-wrap: nowrap;
}
  #greeting .tx_box {
	  width: 50%;
    padding: 80px 50px;
	  margin: 150px 0;
  }
	#greeting .tx_box .sp_none{
	display: inline;
}
	#greeting figure {
		width: 80%;
  margin-left: -20%;
}
}
@media print, screen and (min-width:1366px){
	 #greeting .tx_box {
		 width: 40%;
    padding: 80px 50px;
	  margin: 150px 0;
  }
	#greeting figure {
  margin-left: -10%;
}
}
/*更新プログラム(連動)フォーマット*/
#news {
  padding: 0 0 40px;
}
#news .tit_area {
  position: relative;
  text-align: left;
  width: calc(100% - 30px);
  height: 180px;
  background: #f0f0f0;
  padding: 50px 0 0 30px;
  margin-bottom: 30px;
}
#news .tit_area .title01{
	margin-bottom: 0;
}
#news .tit_area .btn01 {
  position: absolute;
  bottom: 30px;
  right: -30px;
}
#news .tit_area .btn01 a{
	font-size: 18px;
}
#news01 {
  width: 100%;
  overflow: hidden;
}
#news01 dl {
  text-align: left;
  padding: 0 0 15px 0;
}
#news01 dl dt {
  color: #00a2e5;
}
#news01 dl dd div.newstitle {
  text-align: left;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
#news01 dl dd div.newstitle a {
  text-decoration: underline;
  color: #00a2e5;
}
#news01 dl dd div.newstitle a:hover {
  opacity: 0.7;
}
@media print, screen and (min-width:768px) {
  #news {
    padding: 0 0 70px;
  }
  #news .flex_box {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #news .tit_area {
    width: 260px;
    height: 260px;
    margin-bottom: 0;
  }
  #news01 {
    width: 70%;
  }
  #news01 dl dt {
    float: left;
  }
  #news01 dl dd {
    padding: 0 0 0 120px;
  }
}
/*更新プログラム(TOP完結)フォーマット*/
#news02 {
  width: 100%;
}
#news02 .newsbox {
  overflow: hidden; /* for modern browser */
}
#news02 .newsbox .news_text_area {
  zoom: 1; /*ie6*/
  overflow: hidden;
}
#news02 .newsbox .news_text {
  line-height: 1.5;
}
#news02 .newsbox img {
  margin-bottom: 10px;
}
#news02 .newsbox a:hover img {
  opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha( opacity=60 )";
}
#news02 .newstitle {
  font-size: 16px;
  font-weight: bold;
  color: #6D6D6D;
  padding-left: 10px;
  margin-bottom: 10px;
  border-left: 3px solid #6D6D6D;
}
#news02 .newstitle span {
  font-size: 12px;
}
#news02 .pdf_link {
  margin-top: 10px;
}
#news02 .pdf_link li {
  margin-bottom: 5px;
  text-align: left;
}
#news02 .pdf_link li a {
  padding: 2px 0 2px 28px;
  display: inline-block;
  line-height: 1.4;
  text-decoration: underline;
  background: url(../img/common_img/icon_pdf.png) left top no-repeat;
  background-size: auto 22px;
}
#news02 .pdf_link li a:hover {
  text-decoration: none;
}
@media print, screen and (min-width:768px) {
  #news02 .newstitle br {
    display: none;
  }
}
/*Googlemap*/
#googlemap iframe {
  display: none;
}
.mapbtn {
  background: #666;
  border-radius: 4px;
  margin: 0 auto;
  text-align: center;
  width: 100px;
}
.mapbtn a {
  display: block;
  color: #FFF;
  text-decoration: none;
  padding: 10px;
}
.mapbtn a:hover {
  text-decoration: underline;
}
@media print, screen and (min-width:768px) {
  #googlemap iframe {
    display: block;
  }
  .mapbtn {
    display: none;
  }
}