@charset "UTF-8";
/*! このcssはsass（sass/同名の.scssファイル）からコンパイルされています。修正時はこのcssを直接いじらないようにお願いします */
#map {
  padding-top: 220px;
}
@media only screen and (max-width: 1024px) {
  #map {
    padding-top: 18vw;
  }
}
@media only screen and (max-width: 600px) {
  #map {
    padding-top: 38vw;
  }
}
@media only screen and (max-width: 400px) {
  #map {
    padding-top: 46vw;
  }
}
#map .page_title {
  position: absolute;
  z-index: 2;
  top: 55px;
  left: 0;
  width: 100%;
  margin: 0 0 7rem;
  padding: 0;
}
@media only screen and (max-width: 1024px) {
  #map .page_title {
    top: 50px;
  }
}
@media only screen and (max-width: 600px) {
  #map .page_title {
    margin: 0 0 0rem;
  }
}
#map .page_title::before {
  display: none;
}
#map .page_title::after {
  background-image: url("../images/map/pagetitile_back.svg");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}
#map .page_title .title {
  padding: 4rem 0 3rem;
  background-color: #ADCACC;
}
@media only screen and (max-width: 1024px) {
  #map .page_title .title {
    padding: 5vw 0 1rem;
  }
}
@media only screen and (max-width: 600px) {
  #map .page_title .title {
    padding: 6vw 0 1rem;
  }
}
@media only screen and (max-width: 1024px) {
  #map .page_title .title .eng {
    margin: 0 auto 0vw;
  }
}
@media only screen and (max-width: 1024px) {
  #map .page_title .title .eng img {
    height: 5vw;
  }
}
@media only screen and (max-width: 600px) {
  #map .page_title .title .eng img {
    height: 20vw;
  }
}
#map #maparea {
  width: 100%;
  margin: 0 auto 0;
  padding: 150px 0 5rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1024px) {
  #map #maparea {
    padding: 13vw 0 5rem;
  }
}
@media only screen and (max-width: 600px) {
  #map #maparea {
    padding: 16vw 0 5rem;
  }
}
@media only screen and (max-width: 500px) {
  #map #maparea {
    padding: 17vw 0 5rem;
  }
}
@media only screen and (max-width: 400px) {
  #map #maparea {
    padding: 18vw 0 5rem;
  }
}
#map #maparea::after {
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0px;
  width: 100%;
  height: 25vw;
  background-image: -webkit-gradient(linear, left bottom, left top, from(white), to(rgba(255, 255, 255, 0)));
  background-image: linear-gradient(0deg, white, rgba(255, 255, 255, 0));
  content: "";
}
@media only screen and (max-width: 600px) {
  #map #maparea::after {
    height: 45vw;
  }
}
#map #maparea .mapill {
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../images/map/mapback.jpg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
@media only screen and (max-width: 600px) {
  #map #maparea .mapill {
    background-image: url("../images/map/mapback-sp@2x.jpg");
  }
}
#map #maparea .white_ue {
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  left: 0;
  margin: auto;
  width: 100vw;
  height: 100%;
}
#map #maparea .white_ue::before {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0px;
  width: 100vw;
  height: 30vw;
  background-image: -webkit-gradient(linear, left top, left bottom, from(white), to(rgba(255, 255, 255, 0)));
  background-image: linear-gradient(180deg, white, rgba(255, 255, 255, 0));
  content: "";
}
@media only screen and (max-width: 1024px) {
  #map #maparea .white_ue::before {
    height: 50vw;
  }
}
@media only screen and (max-width: 600px) {
  #map #maparea .white_ue::before {
    height: 100vw;
    top: 0;
  }
}
#map #maparea .map_container {
  position: sticky;
  top: 0;
}
#map #maparea .lead {
  text-align: center;
  margin-bottom: 5rem;
}
@media only screen and (max-width: 1024px) {
  #map #maparea .lead {
    margin-bottom: 3rem;
  }
}
#map #maparea .lead h4 {
  font-size: 1.3rem;
  font-weight: 500;
}
@media only screen and (max-width: 600px) {
  #map #maparea .lead h4 {
    font-size: 1.1rem;
  }
}
@media only screen and (max-width: 600px) {
  #map #maparea .lead p {
    font-size: 0.7rem;
  }
}
#map #maparea .shoplist {
  width: 100%;
  margin: 0 auto;
}
#map #maparea .shoplist .is-layout-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 15px 100px;
}
@media only screen and (max-width: 1024px) {
  #map #maparea .shoplist .is-layout-grid {
    gap: 15px 8vw;
  }
}
@media only screen and (max-width: 600px) {
  #map #maparea .shoplist .is-layout-grid {
    display: block;
    padding-left: 30%;
  }
}
#map #maparea .shoplist p {
  padding-left: 20px;
  min-height: 30px;
}
@media only screen and (max-width: 600px) {
  #map #maparea .shoplist p {
    margin: 0 0 15px;
    min-height: 3px;
  }
}
#map #maparea .shoplist p:nth-child(odd) {
  text-align: right;
  padding-left: 0;
  padding-right: 20px;
}
@media only screen and (max-width: 600px) {
  #map #maparea .shoplist p:nth-child(odd) {
    text-align: left;
    padding-left: 24px;
    padding-right: 0;
  }
}
#map #maparea .shoplist p a {
  display: inline-block;
  background-color: #fff;
  border: 1px solid #090000;
  border-radius: 2em;
  padding: 5px 15px;
  line-height: 1.2;
  position: relative;
}
#map #maparea .shoplist p a::before {
  position: absolute;
  top: 0;
  left: -22px;
  background-image: url("../images/map/pin.svg");
  background-repeat: no-repeat;
  background-position: left 2px;
  background-size: 15px;
  width: 15px;
  height: 27px;
  content: "";
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#map #maparea .shoplist p a:hover {
  background-color: #090000;
  color: #fff;
}
#map #maparea .shoplist p a:hover::before {
  -webkit-transform: scale(1.2) translateY(-50%);
          transform: scale(1.2) translateY(-50%);
}
#map #maparea .shoplist p:nth-child(odd) a::before {
  left: auto;
  right: -22px;
}
@media only screen and (max-width: 600px) {
  #map #maparea .shoplist p:nth-child(odd) a::before {
    left: -22px;
    right: auto;
  }
}
#map .white {
  background-color: #fff;
  position: relative;
  z-index: 1;
}
#map #kanri {
  padding: 6rem 0 0;
}
#map #kanri .wrapper {
  background-image: url("../images/journal/namisen.svg");
  background-position: center top;
  background-size: 1300px;
  background-repeat: no-repeat;
  padding-top: 5rem;
}
@media only screen and (max-width: 1024px) {
  #map #kanri .wrapper {
    background-size: 1000px;
  }
}
#map #kanri .j_midashi {
  text-align: center;
  margin: 0 0 3rem;
}
#map #kanri .j_midashi .eng {
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #5F9DA0;
  margin-bottom: 25px;
  letter-spacing: 0.08em;
}
#map #kanri .j_midashi h2 {
  line-height: 1;
  font-weight: 400;
  font-size: 1.9rem;
  letter-spacing: 0.2em;
}
@media only screen and (max-width: 1024px) {
  #map #kanri .j_midashi h2 {
    font-size: 1.5rem;
  }
}
#map #kanri .kanri_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  background-image: url("../images/top/j_namisen.svg");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 1300px;
  padding-bottom: 100px;
  position: relative;
}
@media only screen and (max-width: 1024px) {
  #map #kanri .kanri_list {
    background-size: 1000px;
  }
}
#map #kanri .kanri_list::before, #map #kanri .kanri_list::after {
  position: absolute;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  content: "";
  height: 0;
}
#map #kanri .kanri_list::before {
  background-image: url("../images/top/j_ill3@2x.png");
  width: 110px;
  padding-top: 105%;
  bottom: -15px;
  left: 15%;
}
@media only screen and (max-width: 1200px) {
  #map #kanri .kanri_list::before {
    width: 10vw;
    bottom: -2vw;
  }
}
@media only screen and (max-width: 600px) {
  #map #kanri .kanri_list::before {
    width: 15vw;
  }
}
#map #kanri .kanri_list::after {
  background-image: url("../images/top/j_ill4@2x.png");
  width: 75px;
  padding-top: 140%;
  bottom: -3px;
  right: 15%;
}
@media only screen and (max-width: 1200px) {
  #map #kanri .kanri_list::after {
    width: 7vw;
  }
}
@media only screen and (max-width: 600px) {
  #map #kanri .kanri_list::after {
    width: 12vw;
  }
}
#map #kanri .waku {
  width: 46%;
  margin: 2%;
}
@media only screen and (max-width: 600px) {
  #map #kanri .waku {
    width: 90%;
    margin: 0 auto 30px;
  }
}
#map #kanri .image {
  position: relative;
  border: 1px solid #090000;
  border-radius: 14px;
  padding: 15px;
  margin: 0 0 25px;
}
#map #kanri .image2 {
  border-radius: 8px;
  overflow: hidden;
}
#map #kanri .image2 img {
  width: 100%;
  display: block;
  -webkit-transition-duration: 0.5s;
          transition-duration: 0.5s;
}
#map #kanri .image2 img:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  -webkit-transition-duration: 0.5s;
          transition-duration: 0.5s;
  opacity: 1;
}
#map #kanri .area {
  position: absolute;
  top: 8px;
  left: 8px;
  background-color: #fff;
  padding: 10px;
  border-bottom-right-radius: 5px;
  border-right: 1px solid #090000;
  border-bottom: 1px solid #090000;
  font-weight: 500;
}
#map #kanri h3 {
  font-weight: 500;
  font-size: 1.2re;
  text-align: center;
  margin-bottom: 0.7rem;
}
#map #kanri h3 a {
  position: relative;
  display: inline-block;
  text-decoration: none;
}
#map #kanri h3 a::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  background: #333;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: center top;
          transform-origin: center top;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
#map #kanri h3 a:hover::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
#map #kanri p {
  padding: 0 5%;
  line-height: 1.7;
}
#map #kanri .bt {
  margin-top: 1rem;
}
/*# sourceMappingURL=map.css.map */