@charset "utf-8";
/* CSS Information========
Table of Contents:
 * info

========================== */
#container strong {
  display: inline-block;
}
#container .topicpath {
  margin: 10px auto 0;
}
.head_bg img {
  height: 164px;
  object-fit: cover;
  object-position: 80%;
}
/* =======================
	　とび先リンク配置
========================== */
.link {
  margin-top: -50px;
  padding-top: 50px;
  display: block;
}
/* =======================
	　ページ内リンク
========================== */
.p_navi {
  display: flex;
  justify-content: center;
}
.p_navi li {
  padding: 0 16px;
  text-align: center;
  border-left: #adadad solid 1px;
  display: flex;
  align-items: center;
}
.p_navi li:last-child {
  border-right: #adadad solid 1px;
}
#container a:hover {
  text-decoration: none;
}
.reservation_btn a,
.ski_btn a {
  margin: 0 auto;
  background-color: #4bbfd8;
  color: #fff;
  display: block;
  padding: 10px 5px;
  text-align: center;
}
.ski_btn a {
  width: 97%;
  margin: 0 auto;
  background-color: #4bbfd8;
  color: #fff;
  display: block;
  padding: 10px 5px;
  text-align: center;
}
.ski_btn a:hover {
  background-color: #4bbfd8;
}
.reservation_box {
  margin: 60px auto 20px;
  background-color: #fff;
  border: solid 1px #e5e5e5;
  padding: 3%;
}
.reservation_box h3 {
  display: block;
  width: 100%;
  padding: 10px 0;
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  color: #333;
  line-height: 1.5;
  text-decoration: underline;
  text-decoration-color: yellow;
  text-decoration-thickness: 4px;
  text-underline-offset: -1px;
}
.reservation_box .note {
  text-align: center;
  margin-top: 10px;
}
.sp_on {
  display: block;
}
.mainvisual_ttl {
  line-height: 1.4;
}
#container {
  width: 90%;
  margin: 10px auto 70px;
}
#container .ttl {
  text-align: center;
  margin-top: 30px;
}
.ttl h2 {
  color: #063641;
  font-size: 25px;
  font-weight: 500;
  margin-bottom: 20px;
  line-height: 1.6;
}
.ttl h3 {
  font-size: 2.3rem;
  margin-bottom: 25px;
}
.copy_txt h3 {
  font-size: 22px;
  font-weight: 500;
  text-align: center;
  margin-bottom: 10px;
}
#container .ski_copy {
  text-align: left;
  margin-bottom: 60px;
}
.content_box {
  margin-bottom: 40px;
}
.content_box.list {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
section.datail_ttl {
  margin-top: 50px;
}
#container .main_txt {
  margin: 10px 0 40px 0;
  line-height: 1.8;
}
#container .sub_txt {
  margin: 10px 0 40px 0;
  line-height: 1.8;
}
.menu_btn p {
  margin-bottom: 10px;
}
.menu_btn p a {
  color: #063641;
}
.reservation_box {
  padding: 3% 6% 7%;
}
.charm_list {
  display: flex;
  flex-direction: column;
  gap: 30px;
  text-align: center;
}
.charm_list_text {
  margin-top: 20px;
}
.content_list_header {
  font-size: 22px;
  font-weight: 500;
  line-height: 1.3;
}
.content_list_text {
  container-type: inline-size;
}
.content_list_text > * + * {
  margin-top: 10px;
}
#container #skiresort_map #g_map {
  width: 99%;
  height: 350px;
  margin: 0 auto;
  border: 1px solid #999;
}
.access-time {
  position: absolute;
  z-index: 2;
  width: auto;
  background-color: #4bbfd8;
  padding: 8px 15px;
  border-bottom-right-radius: 10px;
}
.access-time p {
  color: #fff;
  font-weight: 500;
}
#g_map_btn {
  text-align: right;
  display: block;
  margin: 10px auto 30px;
}
.ski_box.apres-ski {
  margin-bottom: 40px;
}
.ski_box .ski_img .ski-slider,
.ski_box .ski_img .after_ski-slider {
  width: 100%;
}
.ski_box .ski_img .ski-slider img,
.ski_box .ski_img .after_ski-slider img {
  width: 100%;
}
.slick-prev,
.slick-next {
  top: 43%;
}
.slick-dots {
  bottom: 8px;
}
#ski_box {
  margin-bottom: 20px;
}
/* タブレット（縦） */
@media screen and (min-width: 768px) {
  .sp_on {
    display: none;
  }
  .pc_on {
    display: block;
  }
  .mainvisual_ttl {
    letter-spacing: 0;
  }
  #container .info p {
    font-size: 1.4rem;
    line-height: 1.5;
    padding: 14px 0;
  }
  .head_bg img {
    height: auto;
    object-fit: cover;
    object-position: 80%;
  }
  .ttl h2 {
    margin-bottom: 30px;
  }
  .copy_txt h3 {
    margin-bottom: 10px;
    font-weight: 500;
    text-align: center;
  }
  .apres-ski .copy_txt p {
    text-align: center;
  }
  #container {
    width: 90%;
    margin: 10px auto 60px;
  }
  #container .ski_copy {
    text-align: center;
    line-height: 2;
    margin-bottom: 60px;
  }
  .p_navi li {
    padding: 0 50px;
  }
  .content_box {
    margin-bottom: 60px;
  }
  .content_box.list {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 30px;
  }
  .content_box.list .ski_box {
    width: calc((100% - 30px) / 2);
  }
  .ski_box .ski_img .ski-slider,
  .ski_box .ski_img .after_ski-slider {
    margin-bottom: 20px;
  }
  .content_box .ski_box .slide_text_l p {
    margin-top: 20px;
    line-height: 2;
  }
  .apres-ski .menu_btn p {
    max-width: calc(50% - 5px);
    min-width: 240px;
  }
  #main .menu .ski_box .menu_img {
    width: 100%;
    margin-bottom: 1%;
  }
  .img_right {
    float: right;
    width: 47%;
  }
  .menu_btn {
    display: flex;
    justify-content: center;
    gap: 2%;
  }
  .reservation_box {
    width: 49%;
    padding: 3% 4% 4%;
    margin-top: 70px;
  }
  .reservation_box h3 {
    margin-bottom: 5px;
  }
  .reservation_box .note {
    margin-top: 15px;
  }
  .charm_list {
    display: flex;
    flex-direction: row;
    gap: 50px 30px;
    flex-wrap: wrap;
  }
  .charm_list_item {
    list-style: none;
    width: calc((100% - 30px) / 2);
  }
  #container #skiresort_map #g_map {
    width: 100%;
    height: 480px;
    margin: 0 auto;
    border: 1px solid #999;
  }
  .ski_box.apres-ski {
    margin-bottom: 60px;
  }
  .skiresort_list {
    display: flex;
    gap: 30px;
  }
}
@media screen and (min-width: 1024px) {
  .sp_on {
    display: none;
  }
  #container {
    width: 1000px;
    margin: 0 auto 70px;
  }
  #container .ttl {
    margin-top: 90px;
  }
  .ttl h2 {
    font-size: 30px;
  }
  .ttl h3 {
    margin-bottom: 40px;
  }
  .p_navi li {
    padding: 0 70px;
  }
  .content_box.list .ski_box {
    width: calc((100% - 60px) / 3);
  }
  .menu_btn {
    flex-wrap: nowrap;
  }
  .charm_list_item {
    list-style: none;
    width: calc((100% - 60px) / 3);
  }
  .content_list_header {
    font-size: 20px;
  }
  .reservation_box {
    margin-top: 90px;
  }
  .copy_txt p {
    line-height: 1.8;
  }
}
