@charset "utf-8";
/* CSS Document */
.mainvisual{
  background:url("../../../common/img/mv-coporate.png")no-repeat center;
  background-size: cover;
}
.title_inner{
  max-width: 1024px;
  width: 100%;
  margin: auto;
}
.title_inner .sec-title {
    color: #222;
    font-size: 4rem;
    font-weight: 800;
}
 .sec-subtitle{
  max-width: 1024px;
  width: 100%;
  margin: auto;
}
a.anchor:target::before{
  content: '';
  margin-top: -200px;
  height: 200px;
  display: block;
  visibility: hidden;
  position: relative;
}
/* 
------------------------------------------------------*/
.menu_list{
  max-width: 780px;
  width: 100%;
  justify-content: space-between;
  display: flex;
  margin: 0 auto 75px;
}
.menu_list li a{
  position: relative;
  background: #164E90;
  color: #fff;
  width: 241px;
  padding: 10px;
  display: block;
  border-radius: 40px;
  text-align: center;
  box-shadow: 2px 4px 5px #0000001A;
  transition: .3s;
}
.menu_list li a:hover{
  opacity: 1;
  transform: translateY(2px);
  box-shadow: 0px 0px 0px #0000001A;
}
.menu_list li .num01::after{
  content: url("../img/icon01.svg");
  position: absolute;
}
.menu_list li .num02::after{
  content: url("../img/icon02.svg");
  position: absolute;
}
.menu_list li .num03::after{
  content: url("../img/icon03.svg");
  position: absolute;
}
.menu_list li .num04::after{
  content: url("../img/icon04.svg");
  position: absolute;
}

.menu_list li a::after{
  position: absolute;
  right: 30px;
  top: 13px;
}

.title_innre{
  max-width: 1024px;
  width: 90%;
  margin: auto;
}
/*会社概要*/
.about{
  
}
/*テーブル*/
.outline_table {
  max-width: 850px;
  width: 100%;
    margin: 40px auto 0;
  border-top: 1px solid #43669e;
  margin-bottom: 100px;
}
.outline_table th {
    background: #5d7dab;
    text-align: center;
    vertical-align: middle;
    color: #fff;
    width: 154px;
    padding: 25px 0;
    border-bottom: 1px solid #43669e;
  font-weight: normal;
}
.outline_table.vel th {
  padding: 0;
  padding-top: 25px;
  vertical-align: top;
}
.outline_table td {
    padding: 25px 40px;
  padding-right: 0;
    background: #fff;
    border-bottom: 1px solid #43669e;
}
.history .outline_table td {
  padding: 25px 30px 25px 30px;
}

.box-flex {
    margin: 50px auto 100px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 850px;
    width: 100%;
}

.box-flex_inner {
    max-width: 520px;
}
.box-flex_inner h3{
  padding-bottom: 20px;
  font-weight: bold;
  font-size: 3rem;
}

.info{
  padding-top: 30px;
}
.map iframe{
  max-width: 1024px;
  width: 100%;
  margin: auto;
  height: 330px;
}
.title_innre .map{
  margin:0 auto 100px;
}
.bank_po01{
  position: relative;
  left: 70px;
}
.bank_po02{
  position: relative;
  left: 59px;
}
.bank_po03{
  position: relative;
  left: 54px;
}
.bank_po04{
  position: relative;
  left: 87px;
}

/*沿革*/
.history{
  margin-top: 90px;
}
.his_flex{
  display: flex;
  justify-content: space-between;
}

/*ボタン*/
.btn_flex{
  max-width: 750px;
  width: 100%;
  justify-content: space-between;
  display: flex;
  margin: auto;
  margin-bottom: 100px;
}
.ser_card {
  position: relative;
  overflow: hidden;
  width: 233px;
  height: 174px;
}
.ser_link{
  position: relative;
}
a.ser_link:hover,
a.ser_link:hover img{
  opacity: 1;
}
.ser_bg{
  transition: .3s;
}
.ser_link:hover .ser_bg{
  transform: scale(1.1);
}
.ser_btn {
    position: absolute;
    bottom: 20px;
    display: flex;
    max-width: 200px;
    width: 100%;
    right: 0;
    left: 0;
    margin: auto;
  justify-content: center;
  align-items: center;
  text-align: center;
  height: 40px;
  background: #fff;
  border-radius: 40px;
  font-weight: bold;
  box-shadow: inset 2px 4px 10px #FFFFFF99, 2px 4px 5px #0000001A;
  font-size: 1.3rem;
}

.ser_btn span{
  position: relative;
  right: 20px;
}

.ser_btn::after{
    content: url("../../../common/img/arrow.png");
    position: absolute;
    right: 15px;
    height: 6px;
    line-height: 0;
}


/* 固有レスポンシブ
------------------------------------------------------
------------------------------------------------------*/
/*タブレット（縦）*/
@media screen and (orientation: portrait) and (min-width: 768px){

}

@media screen and (max-width: 767px) {
a.anchor {
  padding-top:0px;
  margin-top: 0px;
}
.mainvisual {
  background-position: 85%;
}
.wrapper {
    padding-top: 50px;
}
.title_inner {
    max-width: 90%;
}
  .menu_list {
    max-width: 90%;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 auto 50px;
}
  .menu_list li{
    margin-bottom: 20px;
}
/*outline*/	
  .outline_table{
    max-width: 90%;
    margin-bottom: 50px;
  }
.outline_table th {
    display: block;
    width: 100%;
    margin: auto;
}
.outline_table td {
    display: block;
  padding: 25px 25px;
}
  

.box-flex {
    margin: 50px auto;
    justify-content: center;
    max-width: 90%;
    flex-wrap: wrap-reverse;
}
.box-flex_inner h3 {
    padding: 20px 0;
}
.info {
    padding-top: 20px;
}
.title_innre .map {
    margin: 0 auto 50px;
  max-width: 90%;
}
  
  .his_flex p{
    padding-bottom: 20px;
  }
  .btn_flex{
    margin-bottom: 100px;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 90%;
}
.ser_card {
    margin-bottom: 20px;
}
.history .outline_table td {
  padding: 25px 4%;
}
}