@charset "UTF-8";
.main_v_inr {
  background-image: url('../images/items/bg_main_01.jpg'); /* 背景画像のパスを指定 */
  background-size: cover; /* 画面いっぱいに表示 */
  background-position: center; /* 画像を中央に配置 */
  background-repeat: no-repeat; /* 画像の繰り返しをなくす */
  width: 100%;
  height: 500px; /* 例: メインビジュアルの高さ */
  display: flex; /* キャッチコピーを重ねるためのFlexbox */
  justify-content: center; /* 水平方向の中央揃え */
  align-items: center; /* 垂直方向の中央揃え */
}

.main_v_inr .img_copy {
  /* キャッチコピーのスタイル調整 */
  position: relative;
  z-index: 1; /* 背景画像より手前に表示する */
}

.main_v {
  /*height: -webkit-calc(90vh - 80px);
  height: calc(90vh - 80px);*/
  width: 100%;
  /*padding-left: 18%;*/
  margin-top: 80px;
  position: relative;
}

@media screen and (max-width: 1024px) {
  .main_v {
    border: 0;
    width: 100%;
    height: auto;
    padding-left: 0;
    margin-top: 68px;
  }
}

.main_v .vegas-slide {
  border-radius: 0 0 0 50px;
}

@media screen and (max-width: 1024px) {
  .main_v .vegas-slide {
    border-radius: 0;
  }
}

.main_v .vegas-wrapper {
  border-radius: 0 0 0 50px;
}

@media screen and (max-width: 1024px) {
  .main_v .vegas-wrapper {
    border-radius: 0;
  }
}

.main_v .main_v_inr {
  height: -webkit-calc(50vh - 80px);
  height: calc(50vh - 80px);
  width: 100%;
}

@media screen and (max-width: 1024px) {
  .main_v .main_v_inr {
    height: -webkit-calc(40vh - 68px);
    height: calc(40vh - 68px);
  }
}

.main_v .img_copy {
  display: flex;
  position: absolute;
  bottom: 0%;
  left: 0%;
  text-align: center; /* 中央に配置したい場合 */
  font-size: 5.0rem; /* ABOUT USの文字サイズ */
  font-weight: bold; /* ABOUT USを太字に */
  background: linear-gradient(45deg, #f9da79, #bbbd54);
  align-items: center; /* これが上下の揃えを実現します */
  padding-left: 5%;
  padding-right: 5%;
  height: 70px;
  padding-bottom: 5px;
}

.img_copy span {
  font-size: 2.5rem; /* ABOUT USの半分の文字サイズ */
  font-weight: bold; /* 太字を解除 */
  margin-left: 19px;
}

@media screen and (max-width: 1024px) {
  .main_v .img_copy {
    font-size: 3.0rem;
    min-width: auto;
    max-width: 100%;
    bottom: -15%;
    left: 0px;
  }
  .img_copy span {
  font-size: 1.8rem; /* ABOUT USの半分の文字サイズ */
  font-weight: bold; /* 太字を解除 */
  margin-left: 19px;
}
}

.main_v .img_copy img {
  width: 43%;
  min-width: 700px;
}

@media screen and (max-width: 1024px) {
  .main_v .img_copy img {
    width: 90%;
    min-width: auto;
    max-width: 100%;
  }
}

.main_v .img_copy p {
  font-size: 2.3rem;
  font-weight: bold;
  color: #214778;
  margin: 50px 0 0 30px;
  text-shadow: 1px 1px 1px #ffffff;
}

@media screen and (max-width: 1024px) {
  .main_v .img_copy p {
    font-size: 1.6rem;
    margin: 30px 0 0 5px;
  }
}

@media screen and (min-width: 768px) {
  .main_v .movie_link {
    position: absolute;
    bottom: -70px;
    right: 40px;
    width: 510px;
  }
}

@media screen and (max-width: 1024px) {
  .main_v .movie_link {
    margin: 0 auto 45px;
    padding: 0;
  }
}

.main_v .movie_link a {
  display: -webkit-flex;
  display: flex;
  background: #ffffff;
}

@media screen and (max-width: 1024px) {
  .main_v .movie_link a {
    margin-left: 0;
    background: #F9FBFC;
  }
}

.main_v .movie_link a:hover {
  opacity: 0.6;
}

.main_v .movie_link .thum {
  width: 300px;
}

@media screen and (max-width: 1024px) {
  .main_v .movie_link .thum {
    width: 50%;
    margin-right: 0;
  }
}

.main_v .movie_link .txt {
  width: -webkit-calc(100% - 250px);
  width: calc(100% - 250px);
  position: relative;
}

@media screen and (max-width: 1024px) {
  .main_v .movie_link .txt {
    width: 50%;
    border-top: none;
  }
}

.main_v .movie_link .txt h3 {
  text-align: center;
  width: 100%;
  font-size: 1.8rem;
  line-height: 1;
  font-weight: bold;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
}

.main_v .movie_link .txt h3 span {
  margin-top: 10px;
  font-size: 1.2rem;
  font-family: Arial, sans-serif;
  color: #005AC6;
  display: block;
  letter-spacing: 0.05em;
}

@media screen and (max-width: 1024px) {
  .main_v .movie_link .txt h3 {
    font-size: 1.3rem;
    padding: 0;
  }
  .main_v .movie_link .txt h3 span {
    font-size: 1rem;
    line-height: 1.4;
  }
}


/*items 01*/

.items_01 {
  background-color: #e8e4df;
  padding-top: 60px;
  padding-bottom: 60px;
}
.items_02 {
  background-color: #ffffff;
  padding-top: 60px;
  padding-bottom: 60px;
}
.container_items {
  max-width: 1160px;
  margin: 0 auto;
}
.items_title_h3 {
  display: inline-block;
    position: relative;
    min-width: 480px;
    margin: 5px auto;
    background-color: #f9da79;
    color: #000;
    font-weight: bold;
    border-radius: 50px;
    font-size: 2.0rem;
    padding: 5px 5px 5px 25px;
}

/* ---- PC用レイアウト（横並び） ---- */
.items_wrap {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  margin-top: 20px;
}

.text_box {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.items_wrap img {
  max-width: 25%;
  height: auto;
}

/* ---- SP用レイアウト（縦並び） ---- */
@media screen and (max-width: 1024px) {
  .items_01 {
  background-color: #e8e4df;
  padding-top: 60px;
  padding-bottom: 60px;
  padding-left: 25px;
  padding-right: 25px;
}
.items_02 {
  background-color: #ffffff;
  padding-top: 60px;
  padding-bottom: 60px;
    padding-left: 25px;
  padding-right: 25px;
}
.items_title_h3 {
  display: inline-block;
    position: relative;
    min-width: 100%;
    margin: 5px auto;
    background-color: #f9da79;
    color: #000;
    font-weight: bold;
    border-radius: 50px;
    font-size: 2.0rem;
    padding: 5px 5px 5px 25px;
}
  .items_wrap {
    flex-direction: column; /* imgとtext_boxを縦並びにする */
    gap: 10px;
  }

  .text_box {
    /* text_box自体のレイアウトはそのまま縦並びを維持 */
    gap: 5px; /* 必要に応じて調整 */
  }

  .items_wrap img {
    max-width: 100%; /* 画像を画面幅いっぱいに表示 */
  }
}

/*item list用*/
.items_box_list {
  list-style: none;
  padding-left: 0;
}

.items_box_list li {
  /* Flexboxは不要になります */
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: 1rem;
  line-height: 1.6;
}

.items_box_list li::before {
  content: '■';
  position: absolute;
  left: 0;
  color: #333;
  font-size: 1rem;
  top: 0.5em; /* もしくは 0.25rem など、お好みの値に調整 */
}