

*,
*:before,
*:after {
  box-sizing: border-box;
}

li{
    list-style: none;
}

a {
  text-decoration: none;
}


.sr-only {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0;
  border: 0;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.brand img{
  width: 120px;
  margin-bottom: 0.5em;
  @media screen and (max-width: 765px){
    width: 100px;
  }
}

.site-header {
  position: relative;
  position: fixed;
  width: 100%;
  z-index: 1000;
  padding-left: 2em;
  padding-right: 2em;
  @media screen and (max-width: 1070px){
    top: 0;
  }

  @media screen and (max-width: 1070px){
    padding-left: 1em;
    padding-right: 1em;
  }
}

.site-header__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 95%;
  margin: 0 auto;
  max-width: 1400px;
  padding-bottom: 1rem; 
  margin-top: 1em;
}
  @media (min-width: 630px) {
    .site-header__wrap {
      justify-content: initial; } }
@media (min-width: 630px) {
  .site-header__middle {
    margin-left: auto; } }

/* @media (max-width: 629px) {
  .site-header__end {
    padding-right: 4rem; } } */

@media (min-width: 630px) {
  .nav__wrap {
    display: flex; 

    @media screen and (max-width: 1070px) {
      display: none
    }
    }
   }

@media (max-width: 629px) {
  .nav__wrap {
    position: absolute;
    top: 100%;
    right: 0;
    left: 0;
    z-index: -1;
    background-color: #d9f0f7;
    visibility: hidden;
    opacity: 0;
    transform: translateY(-100%);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out; }
    .nav__wrap.active {
      visibility: visible;
      opacity: 1;
      transform: translateY(0); } }

.nav__item a {
  display: block;
  padding: 0.7em; }

.nav__item a:hover{
  opacity: .5;  
  transition: .2s linear;
  cursor: pointer;
}

.nav__toggle {
  display: none; }
  @media (max-width: 629px) {
    .nav__toggle {
      display: block;
      position: absolute;
      right: 1rem;
      top: 1rem; } }









/* =============================================

ヘッダー
============================================= */



.site-header__end{
    display: flex;
    align-items: center;
}






div.hero_img {
    position: relative;
  }
  
  div.hero_img img {
    width: 100%;
  }
  
  div.hero_img {
    position: relative;
  }
  
  div.hero_img img.hero_img_pc {
    width: 100%;
  }
  
  @media screen and (max-width: 765px) {
    div.hero_img img.hero_img_pc {
      display: none;
    }
  }
  
  div.hero_img img.hero_img_sp {
    display: none;
  }
  
  @media screen and (max-width: 765px) {
    div.hero_img img.hero_img_sp {
      display: initial;
      width: 100%;
      height: auto;
    }
  }
  
  .button-container {
    position: absolute;
    bottom: 50px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 3em;
  }
  
  .ml0 {
    margin-left: 0;
  }
  
  .font {
    font-size: 25px;
    padding: 0.5em 1em;
  }
  
  @media screen and (max-width: 1070px) {
    .font {
      font-size: 22px;
    }
  }
  
  @media screen and (max-width: 768px) {
    .font {
      font-size: 20px;
    }
  }
  
  @media screen and (max-width: 575px) {
    .font {
      font-size: 14px;
    }
  }
  
  .line_banner {
    height: 40px;
    width: 40px;
    margin-left: 10px;
  }
  
  
  @media screen and (max-width: 575px) {
    .line_banner {
      margin-left: 15px;
      height: 30px;
      width: 30px;
    }
  }

  .line_banner:hover{
    opacity: .7;
    transition: .2s linear;
  }
  
  .tell_icon {
    height: 40px;
  }
  
  @media screen and (max-width: 1070px) {
    .tell_icon {
      height: 40px;
      width: auto;
    }
  }
  
  @media screen and (max-width: 1070px) and (max-width: 575px) {
    .tell_icon {
      height: 40px;
    }
  }
  
  @media screen and (max-width: 768px) {
    .button {
      padding: 0.7em 1.3em;
    }
  }
  
  @media screen and (max-width: 575px) {
    .button {
      padding: 0.7em 1.3em;
    }
  }


  .button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    color: #fff;
    /* 元の文字色に戻す */
    background-color: #2fa0f6;
    /* 元の背景色に戻す */
    padding: 0.9rem 1.5rem;
    padding-top: 1rem;
    border-radius: 50px;
    text-align: center;

  }

  .font{
    font-size: 18px;
  }
  