@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Yuji+Syuku&display=swap');

body {
  font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'MS P明朝',
    'MS PMincho', serif;
}
h1 {
  font-size: 28px;
}
h2 {
  font-size: 24px;
}
h3 {
  font-size: 20px;
}
hr {
  margin: 20px 0;
}
html {
  scroll-behavior: smooth;
}
/*LOAD*/
.load {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  z-index: 1000;
}
.load img {
  width: 20%;
  min-width: 200px;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
/*HEADER*/
.header_container {
  width: 100%;
  height: 200px;
  /* max-width: 1540px; */
  margin: 0 auto;
}
.header_wrap {
  width: 90%;
  height: 100%;
  margin: 0 auto;
  /* background-color: #fff; */
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.header_logo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 75%;
  gap: 30px;
  max-width: 1050px;
}
.header_logo a {
  width: 40%;
}
.header_logo a img {
  width: 75%;
  height: auto;
  max-width: 400px;
}
.headerinfo {
  width: auto;
  display: block;
}
.headerinfo h1 {
  font-size: 20px;
  font-weight: bold;
}
.headerinfo p {
  margin-top: 10px;
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: 2px;
}
.contact_area {
  width: 25%;
  height: auto;
  text-align: center;
}
.contact_area a {
  display: block;
  background-color: #15003d;
  color: #fff;
  padding: 15px 20px;
  border-radius: 10px;
}
.contact_area a:hover {
  background-color: #00ffea;
  transition: 0.3s;
}
/*header*/
.hero_container {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  height: auto;
  /* overflow: hidden; */
}
.hero {
  background-image: url('../images/main/top/top_hero.jpg');
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  height: 500px;
}
.hero_container ul {
  margin: 20px 40px;
  font-size: 1.1rem;
  letter-spacing: 3px;
}
.hero_container ul li {
  padding: 20px 0 0;
  font-weight: 800;
  line-height: 20px;
  text-align: left;
  list-style: none;
  width: auto;
  color: #222;
}
.hero_container ul :first-of-type {
  padding-top: 10px;
}
.hero_container h2,
.hero_container p {
  display: none;
}

/*メニューSEC*/
.top_menu_container {
  margin: 100px 0;
}
.top_menu_container h2 {
  text-align: center;
}
.top_menu_container hr {
  width: 100%;
  margin: 20px auto;
}
.swiper {
  width: 100%;
  height: 300px;
}
.swiper-wrapper {
  transition-timing-function: linear;
}
.swiper-slide {
  width: auto;
  height: 300px;
  margin-right: 10px;
}
.swiper-slide img {
  height: 100%;
  width: auto;
}
/*appeal_area*/
.appeal_area {
  width: 600px;
  height: auto;
  margin: 0 auto;
}
.appeal_area P {
  font-size: 1.4rem;
  font-family: "Yuji Syuku", serif;
  line-height: 1.8;
  font-weight: bold;
  text-align: center;
}
.contact_btn {
  width: 100%;
  height: auto;
}
.contact_btn a {
  display: block;
  padding: 30px;
  background-color: #15003d;
  color: #fff;
  text-align: center;
  border-radius: 10px;
  margin-top: 50px;
}

.contact_btn a:hover {
  background-color: #38029d;
  transition: 0.3s;
}

/*GMAP*/
.shop_container {
  height: 600px;
  width: 100%;
  margin: 150px 0;
}
.shop_container h2 {
  text-align: center;
}
.shop_container hr {
  width: 100%;
  margin: 20px auto;
}
.shop_wrap {
  display: flex;
  height: 600px;
  width: 100%;
}

.gmap {
  height: 0;
  overflow: hidden;

  position: relative;
  width: 50%;
  height: 600px;
}
.gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 600px;
  width: 100%;
}
.shop_info {
  padding: 30px;
  background-color: #15003d;
  color: #fff;
  width: 50%;
}
.shop_info h5 {
  font-size: 20px;
  margin-top: 30px;
}
.shop_info p {
  font-size: 16px;
  line-height: 2;
  letter-spacing: 1px;
  padding-top: 5%;
}
.shop_info p:last-child {
  padding-top: 5px;
}
/*GMAP*/
/*お知らせSEC*/
.info_sec {
  width: 80%;
  height: auto;
  margin: 150px auto;
}
.info_sec > hr {
  margin-bottom: 0;
}
.info_wrap ul li {
  border-bottom: 1px dotted #333;
}
.info_wrap ul li:nth-child(3) {
  border-bottom: none;
}
.info_wrap ul li a {
  display: block;
  padding: 20px;
  text-align: center;
  width: 100%;
  height: 100%;
  color: #333;
}

.title {
  display: inline-block;
  text-align: left;
  font-size: 16px;
}
.title span {
  font-size: 14px;
  margin-right: 50px;
}
.info_wrap hr {
  margin-top: 0;
}
/*FOOTER*/
footer {
  width: 100%;
  height: auto;
  background-color: #15003d;
  color: #fff;
}

.footer_container {
  width: 80%;
  height: auto;
  margin: 0 auto;
  position: relative;
  padding: 50px 0;
}
.footer_wrap {
  display: flex;
  align-items: start;
  justify-content: flex-start;
  gap: 90px;
  font-size: 14px;
}

.footer_shop_info h4 {
  font-size: 16px;
  margin: 10px 0;
}
.footer_shop_info h5 {
  font-size: 18px;
  margin: 10px 0;
}
.footer_shop_info p {
  font-size: 14px;
  letter-spacing: 3px;
  line-height: 2;
}
.footer_container > p {
  font-size: 12px;
  position: absolute;
  bottom: 20px;
  right: 0;
  color: #38029d;
}
/*****************************TOPへbtn*/
#page_top {
  width: 50px;
  height: auto;
  position: fixed;
  right: 10px;
  bottom: 50px;
  opacity: 1;
  z-index: 998;
}
#page_top a {
  width: 100％;
  height: auto;
  text-decoration: none;
}
.fa-arrow-up {
  font-size: 32px;
  color: #b4b4b4;
}

/*************TOPへbtn*/
@media screen and (max-width: 1250px) {
  .swiper-slide {
    width: auto;
    height: 200PX;
  }
}
@media screen and (max-width: 930px) {
  .swiper-slide {
    width: 45%;
    height: auto;
  }
  .header_logo {
    display: block;
    width: 70%;
  }
  .header_logo a img {
    width: 60%;
    max-width: 240px;
  }
  .contact_area {
    width: 40%;
  }
}
/*レスポンシブ*/
@media screen and (max-width: 855px) {
  /*HEADER*/
  .header_container {
    height: auto;
    padding: 30px 0;
  }
  .header_wrap {
    flex-direction: column;
    gap: 30px;
  }
  .header_logo {
    width: 100%;
  }
  .contact_area {
    width: 100%;
  }
  .fix_header.is_show {
    top: -70px;
  }
  /*HEADER*/
  .hero_container {
    flex-direction: column;
  }
  .hero_container h2 {
    display: block;
    /* font-size: 18px; */
    text-align: center;
    margin: 20px auto;
  }
  .hero_container p {
    display: block;
    font-size: 16px;
    text-align: center;
    line-height: 1.8;
    margin: 0 auto;
  }
  /*MENU SEC*/
  .swiper {
    width: 100%;
    height: auto;
  }
  .swiper-slide {
    width: auto;
    height: 200px;
    margin-right: 10px;
  }
  /*FOOTER*/
  .footer_wrap {
    flex-direction: column-reverse;
    gap: 0;
  }
  .footer_shop_info {
    border-top: 1px solid #333;
    margin-top: 40px;
    padding-top: 30px;
    width: 100%;
  }
  /*FOOTER*/
}
@media screen and (max-width: 720px) {
  .hero {
    height: 300px;
  }
  .appeal_area {
    width: 90%;
  }
  .appeal_area P {
    font-size: 1.1rem;
    font-family: "Yuji Syuku", serif;
    font-weight: 400;
    font-style: normal;
  }
  .contact_btn {
    width: 100%;
  }
  .shop_wrap {
    display: block;
    padding-bottom: 50px;
  }
  .shop_container {
    height: 400px;
    width: 100%;
  }
  .gmap {
    width: 100%;
    height: 400px;
  }
  .gmap iframe {
    height: 400px;
    width: 100%;
  }
  .shop_info {
    display: none;
  }
  .info_sec {
    margin: 650px auto 100px;
  }
}
@media screen and (max-width: 450px) {
  .top_menu_wrap ul {
    flex-direction: column;
  }
  .top_menu_wrap ul li {
    width: 100%;
  }
  .info_wrap .title span {
    display: block;
    margin-bottom: 10px;
  }
}
