@charset 'utf-8';

#deliveryBlock {
  margin-bottom: 35px;
}

.howtoBox {
  border: 1px solid #4e2509;
  width: 758px;
  /* height: 120px; */
  margin-bottom: 10px;
  background-color: #fdffd4;
  box-sizing: border-box;
  position: relative;
}

.stepImg {
  /* background-color: #333333; */
  width: 109px;
  height: 118px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}

.stepImg::before {
  content: "";
  display: block;
  /* position: absolute; */
  width: 100%;
  height: 100%;
  /* top: 15px; */
  background-image: url("/img/howto/bg_step.png");
  background-repeat: no-repeat;
  background-position: center;
}

.stepImg::after {
  position: absolute;
  top: 39%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #ffffff;
  font-size: 61px;
}

.step1 .stepImg::after {
  content: "1";
}

.step2 .stepImg::after {
  content: "2";
}

.step3 .stepImg::after {
  content: "3";
}

.step4 .stepImg::after {
  content: "4";
}

.howtoDescription {
  /* height: 118px; */
  width: 560px;
}

.howtoDescription h4 {
  border-bottom: 1px solid #ff697b;
  font-weight: bold;
  font-size: 16px;
  padding-top: 17px;
  text-indent: 11px;
  padding-bottom: 15px;
  width: 97%;
  color: #ff697b;
}

.howtoDescription p {
  padding: 11px 0 20px 11px;
  line-height: 1.2em;
  width: 85%;
  box-sizing: border-box;
  position: relative;
}

.supplementText {
  line-height: 1.5em;
  margin: 0 auto 10px;
  position: relative;
  letter-spacing: -0.03em;
}

.hotelBtn {
  /* bottom: -17px;
  height: 32px;
  position: absolute;
  right: 10px;
  width: 170px;
  bottom: 10px; */
  /* background: linear-gradient(0deg, #ff4953, #ff606b);
  border: 1px solid #ff697b;
  transition: all .3s ease; */
  background: url("/img/howto/btn_hotelGuide.png")no-repeat scroll 0 0;
  bottom: 10px;
  height: 30px;
  line-height: 30px;
  position: absolute;
  right: 10px;
  text-align: center;
  width: 168px;
  box-shadow: 0 2px 3px -2px rgb(0 0 0 / 20%);
  box-sizing: border-box;
}

.step1 .hotelBtn {
  background: url(/img/howto/btn_storeAccess.png)no-repeat scroll 0 0;
}

.hotelBtn:hover {
  background-position: left bottom;
}

.hotelBtn a {
  color: #ffffff;
  display: block;
  font-size: 12px;
  font-weight: bold;
  height: 100%;
  text-indent: -9999px;
}

.smallText {
  font-size: 12px;
}

#googleMapWrap {
  width: 760px;
  position: relative;
}

#contentsWrapper #googleMapWrap h3 {
  font-family: yu-mincho-pr6n, sans-serif;
  font-size: 20px;
  box-shadow: none;
  padding-left: 22px;
  margin: 13px auto 0;
  height: 43px;
  line-height: 2em;
  position: relative;
  border-radius: 7px 7px 0px 0px;
  background-color: #000000;
  color: #ffffff;
  letter-spacing: -0.03em;
}

#googleMapWrap h3:before,
#googleMapWrap h3:after {
  content: none;
}

#googleMapWrap #googleMapBox {
  position: absolute;
  top: 40px;
  width: 758px;
  background-color: #ffffff;
  border-radius: 0px 0px 7px 7px;
  border-bottom: solid 1px #000000;
  border-left: solid 1px #000000;
  border-right: solid 1px #000000;
}

#googleMapWrap .supplementText {
  width: 720px;
  margin-bottom: 20px;
  padding-top: 7px;
}

.mapWrap {
  width: 723px;
  margin: 0 auto 20px auto;
}

.mapAreaTitle {
  font-size: 16px;
  letter-spacing: 0.01em;
  margin-bottom: 10px;
  color: #ce9b2c;
  font-weight: bold;
}

.eastMapAreaWrap .mapArea {
  position: relative;
  margin-bottom: 22px;
  border-bottom: 1px #a47a1b dashed;
  padding-bottom: 22px;
}

.westMapAreaWrap .mapArea {
  position: relative;
  margin-bottom: 22px;
}

.googleMapBox {
  width: 356px;
  float: left;
  border-bottom: 3px solid #d1b35c;
  border-top: 3px solid #d1b35c;
  border-left: 3px solid #d1b35c;
  height: 261px;
  padding-left: 21px;
}

.mapTextBox {
  margin-bottom: 14px;
  margin-top: 15px;
}

.mapTextBox p {
  font-weight: bold;
  color: #432400;
  font-size: 14px;
}

.mapTextBox p span {
  font-size: 12px;
  letter-spacing: -0.3px;
  font-weight: bold;
}

.googleMap {
  border: 1px solid #ffffff;
  width: 335px;
  height: 196px;
  background-color: #000000;
}

.mapImage {
  border: 3px solid #d1b35c;
  float: right;
  position: relative;
}

.mapImage::before {
  content: "";
  position: absolute;
  top: 78px;
  left: -36px;
  border-top: 19px solid transparent;
  border-right: 33px solid #d1b35c;
  border-bottom: 19px solid transparent;
}

#meetBlock .step1 {
  height: auto;
}

#meetBlock .step1 .stepImg {
  top: 0;
  transform: none;
}

.howtoBoxContent {
  padding-left: 88px;
}

.photos {
  width: 90%;
  margin: 20px auto 19px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.photos li {
  width: 330px;
  border: 1px solid #b6b6b6;
  margin-bottom: 20px;
}

.waitingList .title {
  background-color: #11e190;
  color: #ffffff;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  padding: 10px 0;
}

.waitingList p:not(.title) {
  text-align: center;
  font-weight: bold;
  height: 33px;
  line-height: 33px;
}

.waitingList .title span {
  font-size: 11px;
}

.waitingList iframe {
  width: 100%;
}

.otherPagesBtn {
  display: block;
  width: 160px;
  position: absolute;
  top: 16px;
  right: 0;
}

.otherPagesBtn:hover {
  opacity: 0.7;
}

.otherPagesBtn a {
  background-color: #00d582;
  color: #ffffff;
  display: block;
  font-size: 14px;
  height: 100%;
  line-height: 35px;
  text-align: center;
  text-decoration: none;
  width: 100%;
  border-radius: 2px;
  box-shadow: 0 3px 0 #00ad82;
  transition: all .3s ease;
}

/* =========================================================
 PC用
========================================================= */
@media screen and (min-width: 769px) {
  /* .hotelBtn a::before {
    content: "▶";
    background-color: #fffcb7;
    color: #ff324b;
    height: 100%;
    width: 32px;
    display: inline-block;
    position: absolute;
    left: 0;
  }

  .hotelBtn:hover {
    opacity: 0.7;
  } */
}

/* =========================================================
 スマホ用
========================================================= */
@media screen and (max-width: 768px) {
  h3 {
    font-size: 4.7vw;
    letter-spacing: -0.1vw;
  }

  .supplementText {
    width: 94%;
    margin: 5vw auto;
    line-height: 1.5;
  }

  #deliveryBlock>ul, #meetBlock>ul {
    width: 96%;
    margin: 0 auto;
  }

  .howtoBox {
    width: 100%;
    height: auto;
    margin-bottom: 3vw;
    background-color: #fff7db;
    border-color: #925932;
    /* color: #1d1e1f; */
  }

  .stepImg {
    width: 22%;
    height: 100%;
  }

  .stepImg::before {
    height: 100%;
    /* top: 50%; */
    /* transform: translate(0, -50%); */
    background-position-y: 3vw;
    background-size: 55%;
  }

  .stepImg::after {
    /* bottom: auto; */
    top: 8vw;
    /* transform: translate(0, 90%); */
    /* width: 75%; */
    /* height: 4vw; */
    /* background-size: 45%; */
    font-size: 8vw;
    /* line-height: 4.5vw; */
  }

  .howtoDescription h4 {
    font-size: 5vw;
    padding: 0;
    text-indent: 0.75em;
    width: 100%;
    line-height: 1.3;
  }

  .howtoDescription p {
    padding-top: 4.3%;
    padding-left: 1.2em;
    line-height: 1.3;
    width: 91%;
    margin-bottom: 5%;
  }

  .smallText {
    font-size: 3.2vw;
    line-height: 1.7;
  }

  .supplementText.clearfix>span {
    letter-spacing: 0.1em;
    height: 10vw;
    width: 100%;
    position: static;
    float: none;
    margin-top: 5vw;
    display: block;
  }

  .supplementText.clearfix a {
    font-size: 4vw;
    height: 100%;
    line-height: 10vw;
    width: 90%;
    margin: 0 auto;
  }

  #googleMapWrap {
    width: 96%;
    margin: 0 auto 7vw;
  }

  #contentsWrapper #googleMapWrap h3 {
    font-size: 5vw;
    padding-left: 4vw;
    margin: 3vw auto 0;
    height: 10vw;
    line-height: 10vw;
    letter-spacing: 0;
    text-indent: 0;
    box-sizing: border-box;
    width: 100%;
  }

  #googleMapWrap #googleMapBox {
    width: 100%;
    position: static;
    box-sizing: border-box;
  }

  #googleMapWrap .supplementText {
    width: 94%;
    margin: 0 auto 5vw;
    padding-top: 5vw;
  }

  .mapWrap {
    width: 96%;
    margin: 0 auto;
  }

  .mapAreaTitle {
    font-size: 5vw;
    margin-bottom: 3vw;
    line-height: 1.2;
  }

  .eastMapAreaWrap .mapArea, .westMapAreaWrap .mapArea {
    margin-bottom: 2vw;
    padding-bottom: 0;
    border: none;
    background-color: #ffffff;
  }

  .eastMapAreaWrap .mapArea {
    margin-bottom: 5vw;
  }

  .googleMapBox {
    width: 100%;
    float: none;
    border: none;
    height: auto;
    box-sizing: border-box;
    padding: 0;
  }

  .mapTextBox {
    margin-bottom: 0;
    margin-top: 0;
    background-color: #ce9b2c;
    line-height: 1.3;
    text-indent: 3vw;
    padding: 3% 0;
  }

  .mapTextBox p {
    font-size: 4.2vw;
    color: #ffffff;
    font-weight: normal;
  }

  .mapTextBox p span {
    font-size: 3.2vw;
    font-weight: normal;
    padding-left: 1vw;
  }

  .googleMap {
    width: 100%;
    height: 65vw;
    box-sizing: border-box;
    border: none;
  }

  .mapImage {
    border: none;
    float: none;
    position: relative;
    width: 100%;
    margin: 2vw auto 0;
  }

  .mapImage::before {
    top: 78px;
    left: -36px;
    border-top: 19px solid transparent;
    border-right: 33px solid #d1b35c;
    border-bottom: 19px solid transparent;
    content: none;
  }

  .googleMap iframe {
    width: 100%;
    height: 100%;
  }

  .mapImage img {
    width: 100%;
    height: auto;
  }

  #deliveryBlock {
    margin-bottom: 9vw;
  }

  .howtoBoxContent {
    padding-left: 0;
  }

  .howtoDescription {
    height: auto;
    width: 95%;
    margin-top: 5%;
    padding-left: 15%;
    box-sizing: border-box;
  }

  #meetBlock .step1 .stepImg {
    /* height: 29vw; */
    /* border-bottom: 1px solid #11b877; */
  }

  .photos {
    width: 94%;
  }

  .photos li {
    width: 100%;
    margin-bottom: 3%;
  }

  .waitingList .title {
    font-size: 4.5vw;
    padding: 3% 0;
  }

  .waitingList .title span {
    font-size: 3vw;
    font-weight: inherit;
  }

  .waitingList p:not(.title) {
    height: 10vw;
    line-height: 10vw;
  }

  .waitingList iframe {
    height: 58vw;
  }

  .otherPagesBtn {
    position: static;
    width: 97%;
    margin: 2% auto 5%;
  }

  .otherPagesBtn a {
    height: 9vw;
    line-height: 9vw;
    font-size: 3.44vw;
    font-weight: bold;
    box-shadow: 0 0.8vw 0 #00ad82;
    border-radius: 5px;
  }

  #cautionNeeded {
    display: none;
  }

  .step1 .hotelBtn {
    background-image: none;
    background: #c17f00 none repeat scroll 0 0;
  }

  .hotelBtn {
    position: relative;
    bottom: 0;
    right: 0;
    width: 94%;
    margin: 0 auto 4%;
    height: 12vw;
    background-image: none;
    background: #c17f00 none repeat scroll 0 0;
    box-shadow: 0 3px 0 0 #855800;
    /* border: 1px solid #ff697b; */
    border-radius: 1vw;
  }

  .hotelBtn a {
    color: #ffffff;
    line-height: 12vw;
    text-decoration: none;
    font-size: 4.5vw;
    text-indent: 0;
  }

  /* .hotelBtn a::before {
    content: "▶";
    background-color: #fffcb7;
    color: #ff324b;
    height: 100%;
    width: 12vw;
    display: inline-block;
    position: absolute;
    left: 0;
  } */
}
