@media screen and (max-width: 750px) {

  body {
    font-size: 14px;
  }


  .pc {
    display: none;
  }

  .tab {
    display: none;
  }

  .sp {
    display: block;
  }

  .sp-only {
    display: block;
  }


  /*----------------------------*/



  .teaser .logo {
    width: 200px;
  }


  .teaser .left {
    width: 200px;
    left: -100px;
  }


  .teaser .right {
    width: 200px;
    right: -100px;
  }




  .nav-cover__menu__item a {
    font-size: 18px;
  }

  .nav-cover__menu__item a span {
    font-size: 14px;
  }

  .main-visual.under {
    height: 100px;
  }




  .main-visual .catch {
    width: 100px;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
  }

  .slide {
    height: 600px;
  }


  .slide .item.one {
    background-image: url(../img/slider-1.jpg);
    background-position: 50% 50%;
  }

  .slide .item.two {
    background-image: url(../img/slider-2.jpg);
    background-position: 60% 50%;
  }

  .slide .item.three {
    background-image: url(../img/slider-3.jpg);
    background-position: 30% 50%;
  }

  .slide .item.four {
    background-image: url(../img/slider-4.jpg);
    background-position: 70% 0%;
  }




  .box-1 {
    flex-direction: column;
  }

  .box-1 .item {
    width: 100%;
    margin-bottom: 30px;
  }

  .basic-wrap {
    margin: 30px auto;
  }


  .title-1 {
    width: 100%;
    margin-bottom: 20px;
  }

  .title-1.ex3 {
    width: 100%;
  }


  .title-1.ex4 {
    width: 100%;
  }


  .box-2 {
    flex-direction: column;
    align-items: center;
  }

  .box-2 .item {
    width: 90%;
    margin-bottom: 20px;
    margin-right: 0;
  }

  .box-2.ex .item {
    width: 100%;
    margin-bottom: 20px;
  }

  .box-2 .item:last-child {
    margin-bottom: 0;
  }



  .line {
    display: block;
    width: 40%;
    border-bottom: 3px dotted #9A0025;
    margin: 60px auto;
  }




  .box-3 {
    width: 90%;
    margin-top: 70px;
  }

  .box-3 .inner {
    flex-direction: column;
  }

  .box-3 .inner .item {
    width: 100%;
    margin-bottom: 30px;
  }







  .vision {
    height: 400px;
    background-position: 22%;
  }

  .vision .inner {
    margin-left: 5%;
    width: 60%;
  }


  .title-4 {
    font-size: 22px;
  }


  .topic-list {
    width: 100%;
    margin: 30px auto;
  }

  .topic-list .item {
    display: flex;
    flex-direction: column;
    margin-bottom: 30px;
  }

  .topic-list .item:last-child {
    margin-bottom: 0;
  }


  .topic-list .date {
    padding-right: 0;
    border-right: 0 solid #ddd;
    margin-right: 0;
    border-bottom: 1px solid #ddd;
    margin-bottom: 10px;
    padding-bottom: 5px;
  }


  footer {
    padding: 40px 20px;
  }





  footer .left {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  footer .logo {
    width: 270px;
  }

  footer .address {
    text-align: center;
    margin-top: 15px;
    color: #fff;
    font-size: 12px;
  }

  .footer-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 20px;
    margin-bottom: 30px;
  }


  .footer-nav li {
    margin-bottom: 10px;
  }


  footer .btn-wrap {
    width: 100%;
    flex-direction: column;
  }


  .btn-2 {
    font-size: 18px;
    margin-right: 0;
    margin-bottom: 20px;
  }



  .btn-2 .img-tel {
    width: 30px;
  }

  .btn-2 .img-mail {
    width: 25px;
  }



  footer .copyright {
    text-align: center;
    font-size: 13px;
    margin-right: 0;
  }


  .txt-wrap {
    width: 90%;
  }



  .title-3 {
    font-size: 22px;
  }


  table {
    width: 100%;
    margin: 50px auto;
  }


  table tr {
    text-align: center;
    border-bottom: 1px solid #ddd;

  }

  table td {
    display: block;
    padding-top: 20px;
    padding-bottom: 20px;
    line-height: 1.8;
    letter-spacing: 1.5px;
    margin-bottom: 10px;
  }

  table td:first-child {
    width: 100%;
    vertical-align: middle;
    text-align: center;
    font-weight: 600;
    color: #9A0025;
    padding-bottom: 0px;
  }

  table p:first-child {
    margin-top: 0;
  }




  form {
    width: 100%;
    margin: 30px auto;
    padding-bottom: 0;
  }

  form label {
    width: 100%;
    line-height: 45px;
  }

  form .item {
    display: flex;
    height: auto;
    flex-direction: column;
  }

  .item.message,
  .item.radio {
    align-items: flex-start;
    height: auto;
  }

  label.radio {
    height: 60px;
  }

  label.message {
    height: 45px;
  }

  form input {
    width: 100%;
    height: 60px;
    line-height: 60px;
  }

  textarea {
    width: 100%;
    height: 250px;
    border: 1px solid #ddd;
    padding: 10px;
  }

  .radio .inner {
    width: 100%;
    height: auto;
  }



  .contact-tel {
    display: flex;
    justify-content: center;
    margin-top: 50px;
  }

  .contact-tel img {
    width: 80px;
    margin-right: 20px;
  }

  .contact-tel .inner {
    text-align: center;
  }


  .contact-tel .number {
    display: block;
    font-size: 50px;
    font-weight: 600;
    letter-spacing: 0;
  }

  .contact-tel .time {
    display: block;
    margin-top: 5px;
    font-weight: 600;
    font-size: 18px
  }

  .btn-form {
    font-size: 18px;
    margin: 0 auto;
  }

  .btn-form i {
    margin-right: 5px;
  }


  .contact-tel {
    margin-top: 30px;
  }

  .contact-tel img {
    width: 65px;
    margin-right: 10px;
  }

  .contact-tel .inner {
    text-align: center;
  }

  .contact-tel .number {
    font-size: 40px;
  }

  .contact-tel .time {
    margin-top: 0;
    font-size: 15px
  }


















  #pageTop {
    bottom: 10px;
    right: 10px;
  }

  #pageTop a {
    width: 30px;
    height: 30px;
  }

  #pageTop i {
    font-size: 14px;
    margin-left: 1px;
  }








  /*----------------------------*/

}
