@charset "UTF-8";




/* 改行 */
@media screen and (min-width: 768px) and (max-width: 992px) {
    br.pc {
      display: none;
    }
  
    br.sp {
      display: none;
    }
  
    br.tb {
      display: inline;
    }
  }
  
  @media screen and (max-width: 767px) {
    br.pc {
      display: none;
    }
  
    br.sp {
      display: inline;
    }
  
    br.tb {
      display: none;
    }
  }
  
  @media screen and (min-width: 992px) {
    br.pc {
      display: inline;
    }
  
    br.sp {
      display: none;
    }
  
    br.tb {
      display: none;
    }
  }
  
  html {
    font-size: 62.5% !important;
  }
  
  body {
    font-family: "Noto Serif JP", sans-serif !important;
    font-size: 1.6rem;
    color: #3B3B3B;
    line-height: 1.8;
  }
  
  @media (min-width: 320px) {
    body {
      font-size: 1.4rem;
    }
  }
  
  @media (min-width: 768px) {
    body {
      font-size: 1.6rem;
    }
  }


  /* コンタクトボタン */
@media (min-width: 320px) {
    #top-head .inner .menu_nav a.contact {
      display: flex;
      align-items: center;
          justify-content: center;
      font-family: initial;
      position: relative;
      border-radius: 50px;
      transition: all 1s ease-out;
      background: linear-gradient(90deg, rgba(25, 104, 183, 0.85) 0%, rgba(1, 169, 202, 0.85) 100%);
      font-size: 14px;
      width: 48px;
      height: 48px;
    }
   
  
    #top-head .inner .menu_nav a.contact img {
      width: 22px;
      position: relative;
    }
  }
  
  @media (min-width: 992px) {
    #top-head .inner .menu_nav a.contact {
      font-size: 15px;
      width: auto;
      padding: 0 25px;
    transition: 0.2s;
    margin-left: 1.5rem;
    }
  
    #top-head .inner .menu_nav a.contact img {
      width: 20px;
      margin-right: 8px;
    }
  }
  #top-head .inner .menu_nav a.contact span {
    position: relative;
    color: #FFF;
  }
  #top-head .inner .menu_nav a.contact:before {
    background: linear-gradient(90deg, rgba(1, 169, 202, 0.85) 0%, rgba(25, 104, 183, 0.85) 100%);
    content: "";
    height: 100%;
    left: 0;
    border-radius: 50px;
    position: absolute;
    top: 0;
    transition: all 1s ease-out;
    width: 100%;
  }
  #top-head .inner .menu_nav a.contact:hover:before{
    opacity: 0;
  }
  #top-head .inner .menu_nav a.contact:hover{
    box-shadow: 1px 0px 3px rgba(0, 0, 0, 0.20);
    transition: 0.2s;
  }
  
  @media (max-width: 992px) {
    #top-head .inner .menu_nav a.contact span {
      position: relative;
      display: none;
    }
  }

/* 水色ボタン */
@media (min-width: 320px) {

    .l_btn_box a{
      font-weight: 600;
      border-radius: 6px;
    color: #FFF;
    background: #0AC4F9;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 15px;
    margin-bottom: 1rem;
    font-size: 18px;
    }
  }
  @media (min-width: 992px) {
  
    .l_btn_box a{
      color: #FFF;
      background: #0AC4F9;
      margin-bottom: 0;
      font-size: 20px;
      transition: 0.4s;
      padding: 20px;
      height: 64px;
      }
      .l_btn_box a:hover{
        opacity: 0.8s;
        transition: 0.2s;
        transform: scale(1.01);
      }
    }
    .menu_nav .link_box .active{
      position: relative;
    }
    .menu_nav .link_box .active:after{
      content: "";
      position: absolute;
      border: 1px solid #1aa6e4;
      width: calc(100% - 20px);
      bottom: -7px;
      left: 9px;
    }


/* フッター */
footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
    align-content: center;
  position: relative;
  text-align: center;
}
footer hr{
  width: 100%;
  margin: 0;
  position: absolute;
  top: 0;
  border: 1px solid #ECECEC;
}
@media (min-width: 320px) {
  footer {
    padding-bottom: 5.25rem;
  }
}
@media (min-width: 768px) {
  footer {
    height: 11rem;
    padding-bottom: 0;
   }
}

footer .footer_logo {
  width: 150px;
  margin: 0.75rem 1rem;
}


footer .corp {
  width: 100%;
  color: var(--black);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.3rem;
  font-style: normal;
  font-weight: 300;
  padding: 0;
  margin: 0;
}


@media (min-width: 320px) {}
@media (min-width: 768px) {}