@charset "UTF-8";
/* Scss Document */
/*---------mixin設定-------------*/
/*ブレイクポイント*/
/*-------------------------------

 //共通パーツ

-------------------------------*/
html {
  width: 100%;
}
* {
  box-sizing: border-box;
}
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, table, th, td, figure {
  margin: 0;
  padding: 0;
  font-size: 16px;
}
h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}
ol, ul {
  list-style: none;
}
fieldset, img {
  border: 0 none;
}
object, embed, img {
  vertical-align: top;
}
img {
  width: 100%;
  height: auto;
}
.ginza-page {
  overflow: hidden;
  text-align: center;
}
.ginza-page a {
  color: #000000;
}
.ginza-page a:hover {
  cursor: pointer;
}
.ginza-page h1 {
  text-align: center;
  font-size: 3.5rem;
  font-weight: bold;
}
.ginza-page h2 {
  text-align: center;
  font-size: 3rem;
  font-weight: bold;
}
.ginza-page h3 {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 10px;
}
.ginza-page .operetta {
  font-family: "operetta-32", serif;
  font-weight: 400;
  font-style: normal;
}
.pc_none {
  display: none;
}
.top_cover {
  position: relative;
  width: 100%;
  /* aspect-ratio: 5/9; 比率指定。ない場合は height: 〇〇px; で */
  overflow: hidden;
}
.top_img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* coverで全体に敷き詰める */
  object-position: center top; /* 見せたい位置に合わせて調整（例：上寄せ） */
  z-index: 0;
}
.top_img_content {
  position: relative; /* ← absolute をやめる */
  z-index: 1;
  color: #fff;
  /* 上下の余白で“見せたい高さ”を作る。下方向に伸びれば画像は下で切れる */
  padding: 8% 0 0%;
  text-align: left;
}
.top_img_content .logo {
  width: 50%;
  text-align: left;
  padding-left: 20%;
}
.top_img_content .logo_under {
  padding-top: 42%;
  text-align: center;
}
.top_img_content .sub_title {
  font-size: 1.3rem;
}
.message {
  margin-bottom: 30px;
}
.top_img_content .button {
  border: 1px solid #ffffff;
  color: #ffffff;
  padding: 5px 50px 5px 5px;
}
.top_img_content .button:hover {
  text-decoration: none;
}
.top_img_content .button_p {
  margin-bottom: 80px;
}
.recommend, .limited_price {
  background-color: #20172a;
  color: #ffffff;
  padding: 20px 0;
}
.recommend .flex {
  display: flex;
  margin-bottom: 30px;
}
.recommend .flex.last {
  margin-bottom: 0px;
}
.recommend .recommend_detail_wrap {
  position: relative;
}
.recommend .recommend_detail {
  position: absolute;
  bottom: 30px;
  left: 50px;
  text-align: left;
}
.recommend .price {
  color: #000000;
}
.store {
  background-color: #f7f4ec;
  padding: 50px 0;
}
.limited_price .flex {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0 10px;
}
.limited_price .flex .limited_price_item {
  flex: 1 1 calc(25% - 10px); /* PCで4列（gap考慮） */
}
.limited_price .flex .limited_price_item_text {
  text-align: left;
  padding: 10px 0 0 0px;
  margin-bottom: 10px;
}
.limited_price .flex .limited_price_item_text:hover {
  text-decoration: none;
}
.ginza-page .limited_price a {
  color: #ffffff;
}
.limited_price .price {
  color: #ffffff;
}
.ginza-page .store .flex {
  display: flex;
}
.ginza-page .store .store_img {
  margin: 0px 20px;
}
@media (max-width: 768px) {
  div.wrapper_ {
    margin: 80px auto 0;
    padding: 0;
  }
  html {
    width: 100%;
  }
  .pc_none {
    display: block;
  }
  .ginza-page p {
    font-size: 0.85rem;
  }
  /* SPではパディングやロゴサイズを調整 */
  .top_img_content {
    padding: 20% 0 6%;
  }
  .top_img_content .logo {
    width: 100%;
    text-align: center;
    padding-left: 0%;
  }
  /* SP用に見せたい位置が違えば object-position を切り替え */
  .top_img {
    object-position: center 20%;
  }
  .top_img_content .logo_under {
    padding: 45% 10px 0;
    text-align: center;
  }
  .top_img_content .sub_title {
    font-size: 1.1rem;
  }
  .ginza-page h1 {
    font-size: 2rem;
  }
  .message {
    font-size: 0.85rem;
    padding: 0 10px;
  }
  .ginza-page h2 {
    font-size: 2rem;
  }
  .ginza-page h3 {
    font-size: 1.2rem;
  }
  .recommend .flex {
    display: block;
  }
  .limited_price .flex .limited_price_item {
    flex: 1 1 calc(50% - 10px);
  }
  .limited_price .flex {
    padding: 0 10px;
  }
  .ginza-page .store .flex {
    display: block;
  }
	footer.global {
    clear: both;
    margin: 0;
}
}