@charset "utf-8";
/*全体*/
.content{
  padding: 0 0 64px;
}

/*代表挨拶*/
.messe{
  background: #f8f8f8;
  padding-top: 80px;
}
.messe_inner{
  max-width: 1024px;
  width: 90%;
  margin: auto;
  position: relative;
  z-index: 1;
}
.messe_inner .common_title{
  margin-bottom: 25px;
}
.messe_inner--flex{
  display: flex;
  gap: 20px;
  justify-content: space-between;
  margin-top: 25px;
}
.messe_inner--text{
  max-width: 589px;
  width: 100%;
}
.name{
  text-align: right;
  margin-top: 100px;
}

/*会社メニュー*/
.menu{
  max-width: 1024px;
  width: 90%;
  margin: auto;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 45px 20px;
  margin-top: 65px;
}
.menu a.fir_block{
  position: relative;
  max-width: 1024px;
  width: 100%;
  position: relative;
  text-align: center;
  margin-bottom: 50px;
}
.menu a{
  max-width: 328px;
  width: 100%;
  text-align: center;
}
.menu a .menu_title{
  font-weight: bold;
  font-size: 2.4rem;
  width: 100%;
  text-align: center; 
  letter-spacing: 1.92px;
  line-height: 1.5;
  color: #1D2959;
  padding-top: 10px;
}
.menu .pdf_link{
  position: relative;
}
.menu .pdf_link::after{
  content: "";
  position: absolute;
  bottom: 22px;
  right: 20px;
  background: url(../../common/img/icon_pdf.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  line-height: 1;
  width: 30px;
  height: 22px;
}

@media screen and (max-width: 1279px) {
/* 推奨動作環境1280pxに固定 */
  body {
    width: 1280px;
  }
}

@media screen and (min-width: 767px),print {

  .pagevisual {
    background: url("../img/mv.webp") no-repeat #DEF3FC right;
  }

  .fir_block .menu_img{
    width: 1024px;
  }
  .menu a{
    opacity: 1;
  }
  .menu_img{
    overflow:hidden;
  }
  .menu_img img{
    transition:.5s all;
   }
   .menu a:hover .menu_img img{
     transform:scale(1.1,1.1);
     transition:.5s all;
   }
}

@media screen and (max-width: 767px) {
/* スマホ閲覧時、横幅可変 */
  body {
    width: 100%;
  }
  .pagevisual {
    background: url("../img/sp_mv.webp") no-repeat left;
    background-size: cover;
  }

  /*代表挨拶*/
  .messe{
    padding-top: 50px;
  }
  .messe_inner--flex{
    flex-direction: column;
    align-items: center;
  }
  .name{
    margin-top: 20px;
  }
  .content{
    padding-bottom: 30px;
  }
  .president{
    width: 200px;
  }

  /*会社メニュー*/
  .menu{
    position: relative;
    gap: 10px;
    margin-top: 30px;
  }
  .menu a.fir_block{
    max-width: 100%;
    width: 390px;
    height: auto;
    margin-bottom: 20px;
  }
  .menu a{
    max-width: calc(50% - 5px);
    width: 190px;
    height: auto;
  }
  .menu a .menu_title{
    width: 100%;
    font-size: 1.5rem;
    padding-top: 5px;
    margin-bottom: 10px;
  }
  .menu .pdf_link::after{
    content: "";
    position: absolute;
    bottom: 22px;
    right: 0px;
    width: 18px;
  }
  
}

/* 印刷用設定 */
@media print {

}
@page {
  size: A4;
  margin: 5px;
}
