@charset "UTF-8";
.sapporo .page {
  width: calc(100% - 40px);
  max-width: 1120px;
  padding: 0;
  margin: 0 auto;
}
.page_ttl {
  text-align: center;
  margin-bottom: 2em;
}
.mttl {
  font-size: 20px;
  text-align: center;
  letter-spacing: 0.2em;
  padding-bottom: 10px;
  margin-bottom: 60px;
  position: relative;
}
.mttl:after {
  content: "";
  width: 60px;
  height: 1px;
  margin: 0 auto;
  background-color: #000;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}
.mcopy {
  font-size: 19px;
  text-align: center;
  margin-bottom: 30px;
}
.mcopy span {
  font-size: 15px;
  display: block;
}
#bookinglist .in {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  width: 100%;
  margin: 0 auto 40px;
}
#bookinglist .in .imgbk {
  display: flex;
  align-items: center;
}
#booking #bookinglist .in .imgbk p {
  font-size: 20px;
}
#booking #bookinglist .in .sptel {
  font-size: 40px;
  line-height: 1;
}
#booking .sptel .tx_sp {
  display: none;
}
/* -------------------------------------
form
------------------------------------- */
#formbk {
  color: #000;
  padding: 40px 0 80px;
}
#formbk .mwform-hidden {
  display: none;
}
#formbk .secttl {
  text-align: center;
  writing-mode: initial;
}
#formbk .secttl .jp {
  font-size: 30px;
  font-weight: 600;
  color: #000;
  text-align: center;
  margin-bottom: 30px;
}
#formbk .rgtcontent {
  margin: 0 auto;
}
#formbk .cont .cont_in {
  max-width: 760px;
}
#formbk .cont .txtbk {
  padding-left: 105px;
}
#formbk .page_in {
  align-items: flex-start;
  margin: 0 auto;
  max-width: 754px;
}

#formbk #contact_tel {
}
#formbk #contact_tel .rgtcontent {
  padding: 20px 35px;
  background-color: #e9e9e9;
}
#form #contact_tel .rgtcontent p {
  padding-bottom: 15px;
}
#formbk #contact_tel .rgtcontent p span {
  font-size: 10px;
  display: block;
}
#formbk #contact_tel .rgtcontent dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
#formbk #contact_tel .rgtcontent dl > * {
  display: flex;
  align-items: center;
  padding: 10px 0;
}
#formbk #contact_tel .rgtcontent dl dt {
  font-size: 10px;
  width: 70px;
  border-top: 1px solid #000;
}
#formbk #contact_tel .rgtcontent dl dd {
  font-size: 15px;
  width: calc(100% - 70px);
  border-top: 1px solid #000;
}
#formbk #contact_tel .rgtcontent dl dd a {
  display: inline-block;
}
#formbk .sttl {
  text-align: center;
}
/* -------------------------------------
form
------------------------------------- */

/* #form .hidden {
  font-size: 0;
} */
select {
  -webkit-appearance: none; /* ベンダープレフィックス(Google Chrome、Safari用) */
  -moz-appearance: none; /* ベンダープレフィックス(Firefox用) */
  appearance: none; /* 標準のスタイルを無効にする */
}

::-ms-expand {
  /* select要素のデザインを無効にする（IE用） */
  display: none;
}

#form {
  max-width: 640px;
  margin: 0 auto 40px;
}

#form .fbk {
  margin-bottom: 90px;
}

#form .sttl {
  font-size: 16px;
  display: flex;
  align-items: center;
  padding-bottom: 5px;
  margin-bottom: 27px;
  border-bottom: 1px solid #000;
}

#form span.must {
  color: #fff;
  font-size: 12px;
  text-align: center;
  line-height: 1;
  width: 38px;
  padding: 3px 5px;
  margin-left: 10px;
  background-color: #000;
}

#form dl {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#form dl dt {
  font-size: 14px;
  display: flex;
  width: 110px;
  padding: 0 0 27px 0;
  margin-bottom: 27px;
  border-bottom: 1px solid #000;
}
#form dl dt label {
  align-self: center;
}
#form dl dd {
  width: calc(100% - 110px);
  padding: 0 0 27px 0;
  margin-bottom: 27px;
  border-bottom: 1px solid #000;
}
#form dl dt:last-of-type,
#form dl dd:last-of-type {
  padding: 0;
  margin: 0;
  border: none;
}

#form dl dd input[type="text" i],
#form dl dd textarea {
  width: 100%;
  padding: 5px 15px;
  box-sizing: border-box;
}
#form dl dd input[type="text" i] {
  /*max-width: 338px;*/
}
#form dl dd.zipflm input[type="text" i] {
  /*max-width: 186px;*/
}
#form dl dd.addflm input[type="text" i] {
  /*max-width: 497px;*/
}
#form dl dd textarea {
  font-weight: normal;
  max-width: 780px;
}

#form input,
#form textarea,
#form select {
  /*color:#999;*/
  font-family: zen-old-mincho, sans-serif;
  border: 1px solid #000;
}
#form .mwform-checkbox-field input {
  width: 17px;
  height: 17px;
  margin: 0 5px 0 0;
  cursor: pointer;
}
#form select {
  color: #000;
  width: 100%;
  padding: 7px 10px;
  background: url(../imgs/form/select_arrow.svg) right 0 center no-repeat;
  background-size: auto 100%;
}
.plan_check {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 1em;
}
.mwform-checkbox-field label,
.mwform-radio-field label {
  display: flex;
  align-items: center;
  min-width: 14.5em;
}
.mwform-checkbox-field-text {
  font-size: 14px;
  cursor: pointer;
}
.mw_wp_form .horizontal-item + .horizontal-item {
  margin: 0 !important;
}
#form textarea {
  width: 100%;
  padding: 7px 10px;
  box-sizing: border-box;
}

#form #pp {
  margin: 44px 0;
}
#form #pp .pp_in {
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
}
#form #pp .pp_in > div {
  width: 17px;
}
#form #pp .pp_in p {
  font-size: 14px;
}
#form #pp .pp_in p a {
  display: inline-block;
  text-decoration: underline;
  color: #000;
}
#form #pp .pp_in .mwform-checkbox-field-text {
  cursor: pointer;
  display: none;
}

#form #pp .pp_in .mwform-checkbox-field,
#form #pp .pp_in .mwform-checkbox-field label,
#form #pp .pp_in .mwform-radio-field label {
  height: 17px;
}

#form .btnblk .confirm_button {
  text-align: center;
  display: inline-block;
  width: 153px;
  background-color: #fff;
  padding: 5px 30px 5px 15px;
  background: url(../imgs/form/rgt_arrow_black.svg) right 12px center no-repeat;
  background-size: 14px auto;
  border: 1px solid #000;
  cursor: pointer;
}
#form .notes {
  font-size: 14px;
  padding-top: 40px;
}

.mw_wp_form .error {
  font-size: 12px;
  width: 150px;
}
#form #pp .pp_in .error {
  position: absolute;
  top: 100%;
}
/* -------------------------------------
form confirm
------------------------------------- */
.mw_wp_form_confirm .cont .txtbk {
  padding-left: 0;
}
.mw_wp_form_confirm #form #pp .pp_in > div {
  width: auto;
}
.mw_wp_form_confirm #form #pp .pp_in p {
  display: none;
}
.mw_wp_form_confirm .btnblk {
  text-align: center;
  display: flex;
  justify-content: space-between;
  max-width: 326px;
  margin: 0 auto;
}
.mw_wp_form_confirm .btnblk .confirm_button.back {
  color: #000;
  text-align: center;
  /*display: inline-block;*/
  width: calc((100% - 20px) / 2);
  max-width: 153px;
  background-color: #fff;
  padding: 5px 15px 5px 30px;
  background: url(../imgs/form/lft_arrow_black.svg) left 12px center no-repeat;
  background-size: 14px auto;
  border: 1px solid #000;
  cursor: pointer;
}
.mw_wp_form_confirm .btnblk .confirm_button {
  color: #000;
  text-align: center;
  /*display: inline-block;*/
  width: calc((100% - 20px) / 2);
  max-width: 153px;
  background-color: #fff;
  padding: 5px 30px 5px 15px;
  background: #000 url(../imgs/form/rgt_arrow_white.svg) right 12px center no-repeat;
  background-size: 14px auto;
  border: 1px solid #000;
  cursor: pointer;
}
.mw_wp_form_complete .txt_c {
  text-align: center;
}
/* -------------------------------------
access
------------------------------------- */

#access #gmap {
  height: 470px;
  margin-bottom: 30px;
}
#access #gmap iframe {
  width: 100%;
  height: 100%;
}
#access .mapbtn {
  color: #fff;
  text-align: center;
  width: calc(100% - 40px);
  max-width: 390px;
  padding: 5px 10px;
  margin: 0 auto;
  background-color: #000;
}
#access .mapbtn span {
  display: inline-block;
  position: relative;
}
#access .mapbtn span:after {
  content: "";
  width: 14px;
  height: 14px;
  background: url(../imgs/arrow_rgt_wh.svg) 0 0 no-repeat;
  position: absolute;
  top: 50%;
  left: 140%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 1160px) {
}
@media screen and (max-width: 1060px) {
}
@media screen and (max-width: 960px) {
}
@media screen and (max-width: 880px) {
  #form .content {
    width: 100%;
  }
}
@media screen and (max-width: 800px) {
}
@media screen and (max-width: 768px) {
  /* -------------------------------------
	booking
	------------------------------------- */
  #booking .btn {
    font-size: 19px;
  }
  #booking #bookinglist li .in .imgbk p {
    font-size: 18px;
  }
  #booking #bookinglist li .in .sptel {
    font-size: 36px;
  }
  #booking .contact_note .inblk dl dt {
    font-size: 18px;
  }
  #booking .contact_note .inblk dl dd .sptel {
    font-size: 29px;
  }
}
@media screen and (max-width: 700px) {
}
@media screen and (max-width: 640px) {
  img[src*="_sp"] {
    display: block;
  }

  img[src*="_pc"] {
    display: none;
  }
  /* -------------------------------------
contact
------------------------------------- */
  #form .cont .txtbk {
    padding-left: 0;
  }
  #form .cont .cont_in {
  }
  #form .page_in {
    padding-right: 0;
  }

  /* -------------------------------------
booking
------------------------------------- */
  #booking .btn {
    font-size: 17px;
  }
  #booking .sptel {
    color: #fff;
    text-align: center;
    line-height: 1;
    padding: 10px;
    border-radius: 20px;
    background-color: #3c503c;
  }
  #booking .sptel .tx_pc {
    display: none;
  }
  #booking .sptel .tx_sp {
    display: block;
    font-size: 20px;
  }

  #booking #bookinglist {
    display: block;
  }
  #booking #bookinglist li {
    width: 100%;
  }
  #booking #bookinglist li:nth-child(1) {
    padding-right: 0;
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-right: none;
    border-bottom: 1px solid #3c503c;
  }
  #booking #bookinglist li:nth-child(2) {
    padding-left: 0;
  }
  #booking #bookinglist li .in {
    margin: 0 auto;
  }
  #booking #bookinglist li .in .imgbk p {
    font-size: 16px;
  }
  #booking #bookinglist li .in .sptel {
    font-size: 17px;
  }
  #booking .contact_note .inblk dl dt {
    font-size: 16px;
  }
  #booking .contact_note .inblk dl dd .sptel {
    font-size: 17px;
  }

  #booking .contact_note .inblk dl {
    display: block;
  }
  #booking .contact_note .inblk dl dt {
    margin-bottom: 20px;
  }
  #booking .contact_note .inblk dl dd {
    width: 100%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 410px) {
  #bookinglist .in {
    flex-direction: column;
  }
}
@media screen and (max-width: 320px) {
}
@media screen and (min-width: 769px) {
}
