@charset "utf-8";

/*--------------------------------------
CONTENTS
--------------------------------------*/
html {
  box-sizing: border-box;
}

img {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

#mashiko_202604 {
  max-width: 704px;
  margin: 0 auto 50px;
  /* line-height:1.8em; */
  box-sizing: border-box;
}

.yellow_line {
  border-bottom: solid 4px #FEE600;
  text-align: center;
}

a img:hover {
  opacity: 0.7;
}

a:hover {
  color: inherit;
}

.pc_none,
.pc_none320 {
  display: none !important;
}

.sp_none {
  display: inline-block !important;
}

.mainvisual img {
  width: 704px;
  height: auto;
}

.shopList dt {
  pointer-events: none;
}

#mashiko_202604 .hovernone a img:hover {
  opacity: 1;
}

/* ---------------------------------------------
共通
--------------------------------------------- */
.fs12 {
  font-size: 12px;
}

.fs15 {
  font-size: 15px;
}

.mb60 {
  margin-bottom: 60px !important;
}

.tx_left {
  text-align: left !important;
}

.tx_center {
  text-align: center !important;
}

/*----------------------------------
見出し
----------------------------------*/
h2 {
  background-color: #FE7589;
  color: #FFFFFF;
  font-size: 15px;
  padding: 10px 0 10px 20px;
  margin: 30px 0 20px;
  position: relative;
}

h2:before {
  position: absolute;
  content: "";
  top: 0.5em;
  left: 0.5em;
  width: 4px;
  height: calc(100% - 1em);
  background-color: #FFFFFF;
}

h3 {
  border-left: 4px solid #FE7589;
  line-height: 1.3;
  padding-left: 5px;
  margin-left: 3px;
}

.attention h3 {
  border-left: none;
  line-height: 1.5;
  padding-left: 0;
  margin-left: 0;
}


/*----------------------------------
注意事項
----------------------------------*/
.campList01 {
  margin-bottom: 80px;
}

.campList01 h4 {
  margin-top: 12px;
}

.campList01 h4:first-child {
  margin-top: 0px;
}

.campList01 li {
  text-indent: 0 !important;
  margin-left: 0 !important;
}

.campList01 li p {
  text-indent: 0 !important;
  margin-left: 1em;
  padding-right: 10px;
}

.campList01 li:before {
  display: none !important;
}

.campList01 li div {
  border: 1px solid #bbb;
  padding: 10px;
  margin: 5px 0 12px;
}

/*----------------------------------
バナー
----------------------------------*/
.bannerArea {
  margin-top: 40px;
}

.bannerArea p {
  font-size: 1px;
}

@media screen and (max-width: 768px) {
  .bannerArea p {
    font-size: 12px;
  }
}

/*----------------------------------
チケットのもらいかた
----------------------------------*/
.howto-get-wrapper {
  width: 100%;
  max-width: 768px;
  margin-top: 80px;
  margin-bottom: 32px;
  position: relative;
}

.gift-icon {
  position: absolute;
  top: -35px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}

.gift-icon img {
  width: 177px;
}

@media (max-width: 768px) {
  .gift-icon img {
    width: 144px;
  }
}

.howto-get-card {
  border: 4px solid #FE7589;
  border-radius: 10px;
  overflow: hidden;
}

@media (max-width: 768px) {
  .howto-get-card {
    border-radius: 10px;
  }
}

.howto-get-header {
  background-color: #FE7589;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 62px;
  padding: 0 8px;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
  box-shadow: 0 0 0 1px #FE7589;
}

@media (min-width: 768px) {
  .howto-get-header {
    height: 100px;
    font-size: 28px;
  }
}

.howto-get-body {
  padding: 32px 16px;
}

@media (min-width: 768px) {
  .howto-get-body {
    padding: 48px;
  }
}

.step-header {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 32px;
  display: block;
}

.img-step-heading {
  height: auto;
  max-width: 100%;
}

.text-bold-main {
  text-align: center;
  font-weight: bold;
  font-size: 20px;
  margin-bottom: 32px;
  line-height: 2.2;
}

.step-images {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .step-images {
    gap: 32px;
  }
}

.img-box-sm {
  width: 93px;
}

.img-box-md {
  width: 151px;
}

@media (min-width: 768px) {
  .img-box-md {
    width: 192px;
  }

  .img-box-sm {
    width: 123px;
  }
}

.plus-icon {
  color: #9F6F5C;
  font-size: 30px;
  font-weight: bold;
}

/* ボタンエリア */
.action-buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-bottom: 64px;
}

@media (min-width: 768px) {
  .action-buttons {
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    gap: 24px;
  }
}

.btn-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

@media (min-width: 768px) {
  .btn-wrapper {
    width: auto;
  }
}

.btn {
  width: 100%;
  max-width: 320px;
  border-radius: 9999px;
  font-weight: bold;
  font-size: 18px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 68px;
  border: none;
  text-decoration: none;
}

@media (min-width: 768px) {
  .btn {
    width: 320px;
  }
}

.btn:hover {
  opacity: 0.7;
}

.btn-primary {
  background-color: #FE7589;
  color: #ffffff !important;
}


.btn-secondary {
  background-color: #ffffff;
  border: 2px solid #FE7589;
  color: #333333 !important;
}


.btn-icon {
  position: absolute;
  right: 24px;
  width: 16px;
  height: 16px;
}

.btn-note {
  font-size: 12px;
  margin-top: 10px;
  text-align: center;
}

.text-small {
  text-align: center;
  font-size: 12px;
  margin-bottom: 24px;
}

.step2-image {
  display: flex;
  justify-content: center;
  margin-bottom: 40px;
}

.img-box-lg {
  width: 100%;
  max-width: 280px;
}

.triangle-area {
  display: flex;
  justify-content: center;
  margin-bottom: 32px;
}

/* 下部：強調テキストエリア */
.emphasis-top {
  font-weight: bold;
  font-size: 20px;
  margin-bottom: 8px;
  text-align: center;
}

.emphasis-main {
  color: #FE7589;
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin-bottom: 16px;
}

@media screen and (max-width: 768px) {
  .emphasis-main {
    display: block;
    text-align: center;
  }
}

.emphasis-main-num {
  font-weight: bold;
  font-size: 28px;
}

.emphasis-main-text {
  font-size: 21px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .emphasis-main-num {
    font-size: 41px;
  }
}

@media (min-width: 768px) {
  .emphasis-main-text {
    font-size: 26px;
  }
}

.emphasis-bottom {
  font-size: 12px;
  text-align: center;
}


/*----------------------------------
駐車場について
----------------------------------*/
.parking-info-card {
  max-width: 800px;
  margin: 80px 0;
  background-color: #ffffff;
  box-sizing: border-box;
}

.parking-info-title {
  color: #FFFFFF;
  background-color: #9F6F5C;
  font-size: 20px;
  padding: 6px;
}

@media screen and (max-width: 768px) {
  .parking-info-title {
    font-size: 16px;
  }
}

.parking-info-inner {
  border: 1px solid #9F6F5C;
  padding: 30px;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {

  .parking-info-inner {
    padding: 20px 12px;
  }


}


.parking-info-body {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.parking-text-area {
  width: 100%;
}

.parking-description {
  margin-top: 0;
  margin-bottom: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .parking-description {
    text-align: center;
  }
}

.parking-details {
  background-color: #FBF4F2;
  padding: 15px 20px;
  font-size: 14px;
}

.detail-item {
  display: flex;
  margin-bottom: 8px;
}

.detail-item:last-child {
  margin-bottom: 0;
}

.detail-label {
  font-weight: bold;
  white-space: nowrap;
}

.parking-image-area {
  width: 100%;
  display: flex;
  justify-content: center;
}

.parking-image {
  width: 100%;
  max-width: 200px;
  height: auto;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .parking-info-body {
    flex-direction: row;
    align-items: center;
    gap: 40px;
  }

  .parking-text-area {
    flex: 1;
  }

  .parking-image-area {
    width: auto;
    flex-shrink: 0;
  }

  .parking-image {
    width: 200px;
    max-width: none;
  }
}

/*----------------------------------
アプリダウンロードボタン
----------------------------------*/
#mashiko_202604 .payMethod-title {
  background-color: #FEE600;
  font-size: 20px;
  padding: 6px;
}

@media screen and (max-width: 768px) {
  #mashiko_202604 .payMethod-title {
    font-size: 16px;
  }
}

#mashiko_202604 .payMethod {
  background-color: #FFFDE9;
  padding: 25px;
  border: 1px solid #FEE600;
  margin-bottom: 80px;
}

#mashiko_202604 .payMethod p {
  font-size: 16px;
}

@media screen and (max-width: 768px) {
  #mashiko_202604 .payMethod p {
    font-size: 15px;
  }
}

#mashiko_202604 .payMethod a {
  font-size: 13px;
}

@media screen and (max-width: 768px) {
  #mashiko_202604 .spebubble {
    font-size: 12px !important;
  }
}

#mashiko_202604 .payMethod a {
  font-size: 13px;
}

#mashiko_202604 .payMethod .payMethod_step-wrap {
  box-sizing: border-box;
  display: block;
  justify-content: space-between;
  s align-items: center;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app {
  display: flex;
  overflow: hidden;
  justify-content: space-between;
  width: 100%;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple,
#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google {
  width: 315px;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple {
  margin-right: 15px;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google {
  margin-right: 10px;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple p,
#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google p {
  background-color: #333333;
  padding: 3px;
  color: #fff;
  margin-bottom: 12px;
  text-align: center;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .app_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  align-items: center;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .app_btn img {
  width: 75px;
  height: auto;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google a img {
  margin-left: -10px;
}

#mashiko_202604 .payMethod .payMethod_step-wrap .app_btn a img {
  height: 54px;
  width: auto;
  margin-right: 20px;
}

@media screen and (max-width: 768px) {
  .pc_none {
    display: inline-block !important;
  }

  .sp_none {
    display: none !important;
  }


  /*----------------------------------
  コンテンツ
  ----------------------------------*/

  .title02 {
    width: auto;
  }

  .mainvisual,
  .mainvisual img {
    width: 100%;
  }
}

@media screen and (max-width: 430px) {

  /*----------------------------------
  バナー
  ----------------------------------*/
  .bannerArea {
    margin-bottom: 40px;
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /*----------------------------------
  アプリダウンロードボタン
  ----------------------------------*/
  #mashiko_202604 .payMethod {
    padding: 10px;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap {
    margin: 30px 0 40px;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod .payMethod_step-wrap {
    display: flex;
    flex-direction: column;
    padding: 20px;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app {
    display: flex;
    flex-direction: column;
    margin-top: -10px;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple,
  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google {
    margin-left: 0;
    width: 100%;
    flex-direction: column;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-google a img {
    margin-left: 0;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .app_btn,
  #mashiko_202604 .payMethod .payMethod_step-wrap .app_btn a {
    width: 100%;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .app_btn a {
    text-align: center;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple a img:first-child {
    margin-bottom: 15px;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .payMethod_app .payMethod_app-apple a img {
    box-sizing: border-box;
  }

  #mashiko_202604 .payMethod .payMethod_step-wrap .app_btn a img {
    width: 60%;
    height: auto;
    margin: 0;
  }
}