@charset "UTF-8";
* {
  box-sizing: border-box;
  margin: 0 auto;
}

body {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  position: relative;
  background-image: url(../images/bg.jpg);
  background-size: cover;
  background-repeat: no-repeat no-repeat;
  background-attachment: fixed;
}

a {
  color: #fff;
  text-decoration: none;
}

a[href^="tel"] {
  color: black;
  pointer-events: none;
}

img {
  max-width: 100%;
  vertical-align: middle;
}

.w1200 {
  max-width: 1200px;
  margin: 0 auto;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  a[href^="tel"] {
    pointer-events: initial;
  }
}

/*header*/
.header-l_wrap {
  background-color: #000;
  display: flex;
  justify-content: space-between;
  padding: 0.42vw 0.57vw;
  position: sticky;
  z-index: 1;
  top: 0;
}

.header-l_wrap .nav-list {
  display: flex;
  align-items: center;
  color: #fff;
  font-weight: 600;
}

.header-l_wrap .nav-list > li {
  margin-right: 2.86vw;
}

.header-l_wrap .nav-list > li:first-of-type {
  letter-spacing: 0.2em;
}

.header-l_wrap .nav-list > li:last-of-type {
  margin-right: 0;
}

.header-l_wrap .nav-list .icon-list {
  display: flex;
}

.header-l_wrap .nav-list .icon-list li {
  margin-left: 0.52vw;
}

.header-l_wrap .nav-list .icon-list li:first-of-type {
  margin-left: 0;
}

@media screen and (max-width: 1200px) {
  .header-l_wrap .nav-list > li {
    margin-right: 0.6vw;
    font-size: 12px;
  }
}

@media screen and (max-width: 768px) {
  .header-l_wrap {
    padding: 8px 11px;
    /*ボタン外側※レイアウトによってpositionや形状は適宜変更してください*/
    /*ボタン内側*/
    /*activeクラスが付与されると線が回転して×に*/
  }
  .header-l_wrap .logo {
    display: flex;
    align-items: center;
  }
  .header-l_wrap .logo a img {
    width: 45.33vw;
    height: 7.6vw;
  }
  .header-l_wrap .nav-list {
    display: none;
  }
  .header-l_wrap .openbtn1 {
    position: relative;
    /*ボタン内側の基点となるためrelativeを指定*/
    background: #000;
    cursor: pointer;
    width: 50px;
    height: 50px;
    border-radius: 5px;
    z-index: 3;
  }
  .header-l_wrap .openbtn1 span {
    display: inline-block;
    transition: all 0.4s;
    /*アニメーションの設定*/
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
    background: #fff;
    width: 45%;
  }
  .header-l_wrap .openbtn1 span:nth-of-type(1) {
    top: 15px;
  }
  .header-l_wrap .openbtn1 span:nth-of-type(2) {
    top: 23px;
  }
  .header-l_wrap .openbtn1 span:nth-of-type(3) {
    top: 31px;
  }
  .header-l_wrap .openbtn1.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
  }
  .header-l_wrap .openbtn1.active span:nth-of-type(2) {
    opacity: 0;
    /*真ん中の線は透過*/
  }
  .header-l_wrap .openbtn1.active span:nth-of-type(3) {
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
  }
  .header-l_wrap .menu-area {
    position: fixed;
    position: -webkit-fixed;
    z-index: 2;
    right: -100%;
    width: 100%;
    height: 100%;
    transition: all 0.6s;
  }
  .header-l_wrap .menu-area .sp-nav-list {
    display: flex;
    flex-direction: column;
    font-size: clamp(15px, 4vw, 30px);
    padding: 3.33vw 6.67vw 0;
  }
  .header-l_wrap .menu-area .sp-nav-list > li {
    margin-bottom: 6.67vw;
  }
  .header-l_wrap .menu-area .sp-nav-list > li .icon-list {
    display: flex;
  }
  .header-l_wrap .menu-area .sp-nav-list > li .icon-list li {
    margin-right: 5.33vw;
  }
  .header-l_wrap .menu-area .sp-nav-list > li .icon-list li img {
    width: 8vw;
  }
  .header-l_wrap .menu-area .sp-nav-list > li .icon-list li:last-of-type {
    margin-right: 0;
  }
  .header-l_wrap .panelactive {
    right: 0%;
    background-color: #000;
    width: 48%;
    top: 66px;
  }
}

/*ここまでheader*/
/*footer*/
.footer-l_wrap {
  padding: 8.85vw 0 5.21vw;
}

.footer-l_wrap .icon-list {
  display: flex;
}

.footer-l_wrap .icon-list li {
  margin-right: 0.52vw;
}

.footer-l_wrap .content {
  display: flex;
  max-width: 1560px;
  margin-bottom: 4.69vw;
}

.footer-l_wrap .content dt {
  max-width: 100%;
}

.footer-l_wrap .content dd {
  width: 600px;
  padding: 4.06vw;
}

.footer-l_wrap .content dd .img-wrap {
  margin-bottom: 2.08vw;
}

.footer-l_wrap .content dd .address {
  font-size: clamp(12px, 0.83vw, 16px);
  line-height: 1.87;
  font-weight: 600;
}

.footer-l_wrap .content dd .tel {
  font-size: clamp(16px, 1.67vw, 32px);
  font-weight: 600;
  margin: 1.51vw 0;
}

.footer-l_wrap .content dd .tel span {
  font-size: clamp(12px, 0.89vw, 17px);
}

.footer-l_wrap .content dd .time {
  font-size: clamp(12px, 0.83vw, 16px);
  line-height: 1.87;
  margin-bottom: 1.46vw;
  font-weight: 600;
}

.footer-l_wrap .map {
  margin-bottom: 4.17vw;
}

.footer-l_wrap .map img {
  width: 100%;
}

.footer-l_wrap .gmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 30.21vw;
  position: relative;
}

.footer-l_wrap .gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}

.footer-l_wrap .line-btn {
  text-align: center;
  margin: 3.65vw 0 5.21vw;
  font-weight: bold;
}

.footer-l_wrap .line-btn a {
  font-family: "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  background-color: #01b301;
  padding: 1.04vw 3.13vw;
  display: inline-block;
  font-size: clamp(12px, 1.04vw, 20px);
}

.footer-l_wrap .line-btn a img {
  margin-right: 0.78vw;
}

.footer-l_wrap .copy-right {
  text-align: center;
  font-size: clamp(12px, 0.83vw, 16px);
  line-height: 1.87;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .footer-l_wrap {
    padding-top: 0;
  }
  .footer-l_wrap .content {
    flex-direction: column;
    margin-bottom: 18vw;
  }
  .footer-l_wrap .content dt img {
    width: 100%;
  }
  .footer-l_wrap .content dd {
    padding: 8vw 5.33vw 0;
    width: 100%;
  }
  .footer-l_wrap .content dd .img-wrap {
    width: 74.67vw;
    margin-bottom: 8vw;
  }
  .footer-l_wrap .content dd .icon-list {
    justify-content: center;
  }
  .footer-l_wrap .content dd .icon-list li {
    margin-right: 5.33vw;
    width: 9.33vw;
  }
  .footer-l_wrap .content dd .icon-list li:last-of-type {
    margin-right: 0;
  }
  .footer-l_wrap .content dd .address {
    font-size: clamp(15px, 4vw, 30px);
    line-height: 1.53;
  }
  .footer-l_wrap .content dd .tel {
    margin: 4.67vw 0 8vw;
    font-size: clamp(15px, 4vw, 30px);
    line-height: 1.53;
  }
  .footer-l_wrap .content dd .tel span {
    font-size: clamp(15px, 4vw, 30px);
  }
  .footer-l_wrap .content dd .time {
    margin-bottom: 5.33vw;
    font-size: clamp(15px, 4vw, 30px);
    font-weight: 600;
  }
  .footer-l_wrap .map {
    margin-bottom: 9.33vw;
  }
  .footer-l_wrap .gmap {
    padding-bottom: 96vw;
  }
  .footer-l_wrap .copy-right {
    padding: 8.67vw 0;
    font-size: clamp(10px, 2.67vw, 20px);
  }
}

/*ここまでfooter*/
