@charset "utf-8";
/* CSS Document */

/*================================
ページ共通
================================*/
/*テーブル
================================*/
.table{
  border-color: #E4E4E4;
}
.table:last-child{
  margin-bottom: 0;
}
.table th{
  font-weight: normal;
  background-color: #F2F5F7;
}
@media (min-width: 768px){
  .table>:not(caption)>*>*{
    padding: 1rem;
  }
  .table tr:first-child th,
  .table tr:first-child td{
    border-top-width: 1px;
  }
}
@media (max-width: 767px){
  .table-responsive{
    font-size: .75rem;
  }
  .table tr:first-child th{
    border-top-width: 1px;
  }
  .spblock_table th,
  .spblock_table td{
    width: 100%;
    display: block;
  }
  .between_table td:last-child{
    text-align: right;
  }
}

/*リスト
================================*/
.asterisk_list{
  list-style: none;
  padding-left: 1.3rem;
}
.asterisk_list li{
  position: relative;
}
.asterisk_list li::after{
  content: '＊';
  display: inline-block;
  position: absolute;
  top: .5px;
  left: -1.2rem;
}

/*================================
事業紹介
================================*/
.work_ttl{
  position: relative;
  z-index: 0;
  margin-bottom: 4rem;
}
.work_ttl h2{
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  background-color: #fff;
  font-weight: bold;
  margin-bottom: 0;
  padding: 1rem 2rem;;
}
.work_frame{
  margin-top: 2rem;
}
.work_frame img{
  margin-bottom: 1rem;
}
.work_frame h3{
  color: #1E73DC;
  font-size: 1.3rem;
  font-weight: bold;
}
.private_txt{
  text-align: center;
}
.private_txt p{
  display: inline-block;
  text-align: left;
}

/*================================
歴史
================================*/
/*初代・先代
================================*/
.his_box{
  border: #CACACA 1px solid;
}
.his_box:not(:first-child){
  margin-top: 1rem;
}
.his_photo{
  max-width: 140px;
}
.his_photo p{
  font-size: 1.2rem;
  font-weight: bold;
  margin-top: .5rem;
  margin-bottom: 0;
}
.his_photo p span{
  font-size: .9rem;
  margin-right: .5rem;
}
.his_box dl{
  margin-bottom: 0;
}
.his_box dl dd:last-child{
  margin-bottom: 0;
}
.his_box dl dd p{
  margin-bottom: 0;
}
.his_box dl dd p span{
  display: block;
  color: #1E73DC;
  font-weight: bold;
  margin-bottom: .2rem;
}

@media (min-width: 768px){
  .his_box{
    display: flex;
    padding: 2rem;
  }
  .his_photo{
    margin-right: 1.5rem;
  }
  .his_box dl{
    flex: 1;
  }
  .his_box dl dt{
    float: left;
    width: 150px;
    overflow: hidden;
    clear: left;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .his_box dl dd{
    margin-left: 160px;
  }
}
@media (max-width: 767px){
  .his_box{
    padding: 1.5rem 1rem;
  }

  .his_photo{
    margin: 0 auto 1rem;
  }
  .his_box dl dd p span{
    margin-top: .2rem;
  }
}

/*沿革
================================*/
.history {
  position: relative;
  margin:0 auto;
  width: 100%;
  max-width:1200px;
}
.history::after{
  content: '';
  width: 1px;
  height: 36px;
  background-image: linear-gradient(to top, #1E73DC 8px, transparent 4px);
  background-size: 2px 10px;
  background-repeat: repeat-y;
  background-position: left top;
  position: absolute;
  top: -36px;
}
.history::before{
  content: '';
  width: 1px;
  height: 100%;
  background: #1E73DC;
  position: absolute;
}
.history .history_item{
  position: relative;
  display: flex;
}
.history .history_item::before{
  content: '';
  width: 8px;
  height: 8px;
  background: #1E73DC;
  position: absolute;
  border-radius: 50%;
}
.history .history_item:last-child{
  padding-bottom: 40px;
}
.history .history_item:last-child::after{
  content: '';
  width: 15px;
  height: 15px;
  background: none;
  position: absolute;
  transform: translateX(-50%) rotate(-45deg);
  border-left: 1px solid #1E73DC;
  border-bottom: 1px solid #1E73DC;
  bottom: 1px;
  left: 0;
}
.history_yaer{
  color: #CACACA;
  font-size: 2rem;
  font-weight: bold;
  border-bottom: #CACACA 1px solid;
}
.history .history_txt h2{
  color: #1E73DC;
  font-weight: bold;
}

@media (min-width: 1200px){
  .history .history_item:not(:first-child){
    margin-top: -200px;
  }
}
@media (min-width: 992px) and (max-width: 1199px){
  .history .history_item:not(:first-child){
    margin-top: -170px;
  }
}
@media (min-width: 992px){
  .history .history_item:nth-of-type(odd) .history_txt,
  .history .history_item:nth-of-type(odd) .history_yaer{
    padding-right: 2.5rem;
  }
  .history .history_item:nth-of-type(even) .history_txt,
  .history .history_item:nth-of-type(even) .history_yaer{
    padding-left: 2.5rem;
  }
  .history .history_txt h2{
    font-size: 1.3rem;
  }
}
@media (min-width: 768px) and (max-width: 991px){
  .history .history_item:not(:first-child){
    margin-top: -130px;
  }
  .history .history_item:nth-of-type(odd) .history_txt,
  .history .history_item:nth-of-type(odd) .history_yaer{
    padding-right: 1.5rem;
  }
  .history .history_item:nth-of-type(even) .history_txt,
  .history .history_item:nth-of-type(even) .history_yaer{
    padding-left: 1.5rem;
  }
}
@media (min-width: 768px){
  .history::after{
    transform: translateX(-50%);
    left: 50%;
  }
  .history::before{
    transform: translateX(-50%);
    left: 50%;
  }
  .history .history_item{
    padding: 0;
  }
  .history .history_item:nth-of-type(even){
    justify-content: flex-end;
  }
  .history .history_item::before{
    top: 44px;
    left: 50%;
    transform: translateX(-50%);
    width: 10px;
    height: 10px;
  }
  .history .history_item:last-child::after{
    left: 50%;
  }
  .history .history_inner{
    width: 50%;
  }
  .history .history_txt{
    margin-top: 1rem;
  }
}
@media (max-width: 991px){
  .history .history_txt h2{
    font-size: 1.15rem;
  }
}
@media (max-width: 767px){
  .history .history_item{
    margin-top: 2rem;
  }
  .history .history_item::before{
    top: 45px;
    left: -4px;
  }
  .history .history_item .history_txt,
  .history .history_item .history_yaer{
    padding-left: 1rem;
  }
}

/*================================
歴史と事業紹介のスライダー
================================*/
/*共通
================================*/
.swiper-container .swiper-button-prev,
.swiper-container .swiper-button-next{
  top: auto;
  bottom: 15px;
  width: 30px;
  height: 30px;
  background-color: #1E73DC;
  opacity: 1;
}
.swiper-container .swiper-button-prev{
  left: auto;
  right: 50%;
  margin-right: 60px;
}
.swiper-container .swiper-button-next{
  left: 50%;
  right: auto;
  margin-left: 60px;
}
.swiper-container .swiper-button-next:after,
.swiper-container .swiper-button-prev:after{
  color: #fff;
  font-size: .5rem;
}
.swiper-container .swiper-pagination{
  bottom: 18px !important;
}
.swiper-container .swiper-pagination-bullet{
  width: 9px;
  height: 9px;
  border: #1E73DC 2px solid;
  background-color: #fff;
  opacity: 1;
}
.swiper-container .swiper-pagination-bullet-active{
  background-color: #1E73DC;
}
/*事業紹介スライダー
================================*/
#work_slider{
  padding-bottom: 60px;
  margin-bottom: 1rem;
}
#work_slider .swiper-slide{
  position: relative;
}
#work_slider .swiper-slide p{
  position: absolute;
  left: 0;
  bottom: 0;
  color: #fff;
  text-align: center;
  padding: .1rem;
  margin-bottom: 0;
}
#work_slider .swiper-slide img{
  margin-bottom: 0;
}
#work_slider .swiper-slide:nth-of-type(odd) p{
  background-color: rgba(0, 0, 0, .8);
}
#work_slider .swiper-slide:nth-of-type(even) p{
  background-color: rgba(30, 115, 220, .8);
}
@media (min-width: 768px){
  #work_slider .swiper-slide p{
    font-size: .9rem;
    width: 120px;
  }
}
@media (max-width: 767px){
  #work_slider .swiper-slide p{
    font-size: .7rem;
    width: 60px;
  }
}
/*歴史スライダー
================================*/
.history_slider{
  padding-bottom: 60px !important;
}
.history_slider .swiper-slide{
  width: 100% !important;
}


/*================================
会社案内
================================*/
#company section:not(:last-child){
  padding-bottom: 0;
}
/*会社概要
================================*/
#company .table:not(:last-child){
  margin-bottom: 3rem;
}
@media (max-width: 767px){
  .permission td:first-child{
    border-bottom-width: 0;
    padding-bottom: 0;
  }
  .permission td:last-child{
    padding-top: 0;
  }
}

/*アクセス
================================*/
#gmap iframe{
  aspect-ratio: 16 / 9;
  max-width: 1000px;
  width: 100%;
  height: auto;
}

/*ごあいさつ
================================*/
.greeting_ttl{
  font-size: 1.3rem;
  font-weight: bold;
  margin-bottom: 1rem;
}
.greeting_wrap p:last-child{
  margin-bottom: 0;
}
.greeting_txt{
  flex: 1;
}
.greeting_photo{
  width: 185px;
}
.greeting_photo p{
  font-size: 1.2rem;
  font-weight: bold;
  margin-top: .5rem;
}
.greeting_photo p span{
  font-size: .9rem;
  margin-right: .5rem;
}
@media (min-width: 768px){
  .greeting_wrap{
    display: flex;
    align-items: flex-start;
  }
  .greeting_photo{
    margin-left: 2rem;
  }
}
@media (max-width: 767px){
  .greeting_photo{
    margin-top: 1rem;
    margin-left: auto;
    margin-right: auto;
  }
}

/*================================
協力会社の皆様へ
================================*/
.download_list{
  margin-top: 1.5rem;
}
.download_list h3{
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 1rem;
}
.download_list ul{
  list-style: none;
  padding-left: 0;
  margin-bottom: 0;
}
.download_list ul li{
  position: relative;
  background-color: #F2F5F7;
}
.download_list ul li::before,
.download_list ul li::after{
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-position: center;
}
.download_list ul li::before{
  left: .5rem;
  width: 30px;
  height: 30px;
}
.download_list ul li:not(.xls)::before{
  background-image: url("../img/icon_pdf.svg");
}
.download_list ul li.xls::before{
  background-image: url("../img/icon_xls.svg");
}
.download_list ul li:not(:last-child){
  margin-bottom: .5rem;
}
.download_list ul li .btn{
  display: block;
  text-align: left;
  border-radius: 0;
  padding: .75rem 3rem;
}
.download_list ul li .btn::after{
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: .5rem;
  width: 36px;
  height: 36px;
  background-image: url("../img/icon_dl.svg");
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
  background-color: #fff;
  border-radius: 50%;
}
@media (hover: hover){
  .download_list ul li:hover{
    background-color: rgba(30, 115, 220, .1);
  }
}
@media (max-width: 767px){
  .download_list ul li .btn{
    font-size: .95rem;
  }
}

/*================================
個人情報保護方針
================================*/
#privacy ul{
  padding-left: 1.3rem;
  margin-bottom: 0;
}
.privacy_contact{
  background-color: #F2F5F7;
  margin-top: 3rem;
  padding: 2rem 1rem;
  text-align: center;
}
.privacy_contact h3{
  width: 100%;
  max-width: 400px;
  color: #1E73DC;
  background-color: #fff;
  font-size: 1.1rem;
  text-align: center;
  padding: .5rem;
  margin: 0 auto 1rem;
  border-radius: 15px;
}
.privacy_contact p{
  display: inline-block;
  text-align: left;
}
.contact_tel{
  color: #1E73DC;
  font-size: 2rem;
  font-weight: bold;
}
.contact_tel i{
  font-size: 85%;
}
.contact_tel span{
  margin-left: .25rem;
}