@charset "UTF-8";

/* 共通 */
.header .hd_logo {
  top: -100%;
}
.header .pcnavbox .item.nav_home a,
.header_nav .nav_item.nav_home a,
.footer .right .menu_item.nav_home a {
  color: var(--color3);
}
.topmenu_container {
  display: block;
}
.sectitlebox .wrap {
  position: relative;
}
.sectitlebox .sec_sub {
  font-size: 18px;
  color: var(--color2);
  margin-bottom: 10px;
}
.sectitlebox .sec_sub::before {
  content: "";
  width: 100px;
  height: 1px;
  background-color: var(--color2);
  vertical-align: middle;
  margin-right: 10px;
  display: inline-block;
}
.sectitlebox .sec_title {
  font-size: 40px;
  font-weight: 500;
  margin-bottom: 50px;
}
.sectitlebox .sec_txt {
  font-size: 18px;
  line-height: 2;
  text-align: justify;
}
.sectitlebox .sec_image {
  position: absolute;
  top: 70px;
  right: 0;
}
.sectitlebox .txt_en {
  font-size: 190px;
  color: rgba(230, 229, 229, .5);
  line-height: 1;
  overflow: hidden;
}
@media screen and (max-width:960px) {
  .header {
    background-color: var(--color5);
  }
  .sectitlebox {
    padding-top: 80px;
    margin-bottom: 20px;
  }
  .sectitlebox .sec_sub {
    font-size: 11px;
  }
  .sectitlebox .sec_title {
    font-size: 28px;
    margin-bottom: 30px;
  }
  .sectitlebox .txt_en {
    font-size: 64px;
    text-align: center;
  }
  .sectitlebox .sec_txt {
    font-size: 16px;
  }
  .sectitlebox .sec_image {
    width: 30%;
    max-width: 100px;
    top: -20px;
  }
}
@media screen and (min-width:961px) {
  .sectitlebox {
    position: relative;
  }
  .sectitlebox::before {
    content: "";
    width: 50%;
    height: 120px;
    background-color: var(--color5);
    position: absolute;
    top: -70px;
    left: 0;
  }
  .sectitlebox .title_inn {
    margin-top: -50px;
    position: relative;
  }
}

/* ファーストビュー */
.fv {
  margin-bottom: 22px;
  position: relative;
}
.fv::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: transparent;
  position: absolute;
  top: 0;
  left: 0;
}
.fv .item.slick-slide {
  height: 620px;
  display: flex;
  align-items: center;
  margin-right: 22px;
}
.fv .item img {
  width: auto;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media screen and (max-width:960px) {
  .fv {
    /* margin-bottom: 13px; */
    margin-bottom: 0;
    padding-bottom: 13px;
    background-color: var(--color5);
  }
  .fv .item.slick-slide {
    height: 350px;
    margin-right: 13px;
  }
}

/* インスタグラム */
.insta {
  background-color: var(--color2);
}
.insta .section {
  padding-bottom: 160px;
}
.insta .wrap {
  position: relative;
}
.insta .flex_inn {
  gap: 70px;
}
.insta .box,
.insta .instabox {
  width: 50%;
  box-sizing: border-box;
}
.insta .box .txt {
  font-size: 22px;
  line-height: 2.5;
  letter-spacing: .1em;
  color: #fff;
  margin-top: 60px;
}
.insta .instabox {
  max-width: 250px;
}
.insta .instabox .sub a {
  font-size: 20px;
  color: #fff;
}
.insta .instabox .sub img {
  margin-right: 10px;
}
.insta .childbox {
  border-radius: 20px;
  border: solid 7px var(--color1);
  background-color: #fff;
  filter: drop-shadow(3px 3px 5px rgba(0,0,0,0.6));
  padding: 60px 0;
  margin-top: 15px;
  position: relative;
}
.insta .childbox::before {
  content: "";
  width: 95px;
  height: 25px;
  border-radius: 0 0 10px 10px;
  background-color: var(--color1);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
}
.insta .childbox .acce01 {
  position: absolute;
  top: 0;
  right: 10px;
}
.insta .childbox .acce02 {
  width: 100%;
  position: absolute;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
}
.insta .childbox #sb_instagram #sbi_images {
  padding: 0;
}
.insta .image01 {
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width:960px) {
  .insta .section {
    padding-bottom: 0;
  }
  .insta .flex_inn {
    flex-wrap: wrap;
    justify-content: center;
  }
  .insta .box,
  .insta .instabox {
    width: 100%;
  }
  .insta .box {
    text-align: center;
  }
  .insta .box .txt {
    font-size: 16px;
  }
  .insta .instabox {
    position: relative;
  }
  .insta .image03 {
    width: 40%;
    position: absolute;
    top: -70px;
    right: -50px;
  }
  .insta .image02 {
    width: 30%;
    margin-top: 20px;
  }
}
@media screen and (min-width:961px) {
  .insta .wrap {
    padding-left: 100px;
  }
  .insta .image02 {
    position: absolute;
    left: 50%;
    bottom: -60px;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
  }
}

/* マップ */
.map {
  background: linear-gradient(160deg, var(--color2) 0%, var(--color2) 50%, transparent 50%, transparent 100%);
}
.map .section {
  padding-bottom: 0;
}
.map .title {
  padding-left: 100px;
}
@media screen and (max-width:1100px) {
  .map .title {
    padding-left: 0;
  }
}
@media screen and (max-width:960px) {
  .map {
    background: linear-gradient(160deg, var(--color2) 0%, var(--color2) 50%, var(--color5) 50%, var(--color5) 100%);
  }
  .map .wrap {
    width: 100%;
  }
  .map .title {
    text-align: center;
  }
  .map .title img {
    width: 190px;
  }
}
@media screen and (min-width:961px) {
  .map .title {
    margin-bottom: -160px;
  }
}

/* プラン */
.plan {
  overflow: hidden;
}
.plan .child_titlebox {
  margin-top: 40px;
}
.plan .child_titlebox .flex_inn {
  align-items: center;
  justify-content: space-between;
  position: relative;
}
.plan .childbox .txt {
  font-size: 18px;
  color: var(--color2);
  margin-bottom: 10px;
}
.plan .childbox .txt::before {
  content: "";
  width: 100px;
  height: 1px;
  background-color: var(--color2);
  vertical-align: middle;
  margin-right: 10px;
  display: inline-block;
}
.plan .child_title {
  font-size: 40px;
  font-weight: 500;
}
.plan .child_titlebox .txt_en {
  font-size: 190px;
  color: rgba(230, 229, 229, .5);
  line-height: 0;
}
.plan .image01 {
  position: absolute;
  top: -110px;
  right: 0;
}
.plan .list {
  flex-wrap: wrap;
  gap: 60px;
  margin-top: 80px;
}
.plan .item {
  width: calc((100% - 120px)/3);
  background: linear-gradient(135deg, var(--color2) 0%, var(--color2) 90%, var(--color3) 90%, var(--color3) 100%);
  box-sizing: border-box;
  transition: all .6s;
}
.plan .item:hover {
  opacity: .75;
}
.plan .item a {
  padding: 0 20px 30px;
  display: block;
}
.plan .item .pict {
  margin-top: -50px;
}
.plan .item a:hover .pict img {
  filter: alpha(opacity=1);
  -moz-opacity: 1;
  opacity: 1;
  transition: all .3s;
}
.plan .item .list_title {
  font-size: 22px;
  color: #fff;
  margin-top: 30px;
}
.plan .item .txtbox {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 20px;
  margin-bottom: 25px;
}
.plan .item .txt {
  width: 100%;
  box-sizing: border-box;
}
.plan .item .txt span {
  line-height: 30px;
  color: var(--color2);
  background-color: #fff;
  padding: 0 10px;
  display: inline-block;
}
@media screen and (max-width:960px) {
  .plan {
    background-color: var(--color5);
  }
  .plan .child_titlebox .flex_inn {
    display: block;
  }
  .plan .image01 {
    width: 30%;
    max-width: 120px;
    top: 0;
  }
  .plan .item {
    background: linear-gradient(135deg, var(--color2) 0%, var(--color2) 92%, var(--color3) 92%, var(--color3) 100%);
  }
  .plan .childbox .txt {
    font-size: 11px;
  }
  .plan .child_title {
    font-size: 28px;
  }
  .plan .child_titlebox .txt_en {
    font-size: 64px;
    line-height: 1;
  }
  .plan .list {
    gap: 100px;
  }
  .plan .item {
    width: 100%;
  }
}
@media screen and (min-width:961px) {
  .plan .titlebox {
    padding-left: 100px;
  }
  .plan .child_titlebox .txt_en {
    position: absolute;
    bottom: 80px;
    right: 0;
    z-index: -1;
  }
}

/* 動画 */
.movie {
  aspect-ratio: 16 / 9;
  line-height: 0;
  position: relative;
}
.movie video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 施設の紹介 */
.facilities {
  padding-bottom: 150px;
}
.facilities .list {
  flex-wrap: wrap;
  gap: 115px 100px;
}
.facilities .item {
  width: calc((100% - 100px)/2);
  box-sizing: border-box;
}
.facilities .item .pictbox {
  margin-bottom: 20px;
  position: relative;
}
.facilities .item .titibox {
  width: 60%;
  height: 90px;
  align-items: flex-end;
  background-color: var(--color5);
  position: absolute;
  left: 0;
  bottom: 0;
}
.facilities .item .item_sub {
  font-size: 20px;
  color: var(--color2);
  white-space: nowrap;
}
.facilities .item .item_sub_b {
  font-size: 34px;
}
.facilities .item .item_title {
  font-size: 30px;
}
.facilities .item .item_title_l {
  font-size: 16px;
}
.facilities .item .txt {
  text-align: justify;
}
.facilities .item .txt span {
  color: #ff0000;
}
.facilities .btnbox {
  gap: 30px;
  margin-top: 30px;
}
.facilities .btnbox .btn {
  width: calc((100% - 30px)/2);
  line-height: 50px;
  box-sizing: border-box;
  position: relative;
}
.facilities .btnbox .btn a {
  width: 100%;
  height: 100%;
  font-size: 14px;
  color: #fff;
  background-color: var(--color2);
  display: block;
  transition: all .3s;
}
.facilities .btnbox .btn a:hover {
  opacity: .75;
}
.facilities .btnbox .btn1 a {
  background-color: var(--color4);
}
.facilities .btnbox .btn i {
  margin-left: 10px;
}
.facilities .btnbox .btn span {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  display: inline-flex;
  transition: all .3s;
}
.facilities .btnbox .btn:hover span {
  right: 10px;
}
@media screen and (max-width:1100px) {
  .facilities .list {
    gap: 85px 40px;
  }
  .facilities .item {
    width: calc((100% - 40px)/2);
  }
}
@media screen and (max-width:960px) {
  .facilities {
    background-color: var(--color5);
    padding-bottom: 80px;
  }
  .facilities .list {
    gap: 60px;
  }
  .facilities .item {
    width: 100%;
  }
  .facilities .item .titibox {
    height: 65px;
  }
  .facilities .item .item_sub {
    font-size: 12px;
  }
  .facilities .item .item_sub_b {
    font-size: 24px;
  }
  .facilities .item .item_title {
    font-size: 20px;
  }
  .facilities .item .item_title_l {
    font-size: 12px;
  }
  .facilities .btnbox {
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .facilities .btnbox .btn {
    width: 100%;
    max-width: 260px;
  }
  .facilities .btnbox .btn a {
    font-size: 14px;
  }
}

/* バックイメージ01 */
.backimage01 {
  background-image: url(../img/top/img_top21.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.backimage01 .image {
  padding: 300px 0;
}
@media screen and (max-width:960px) {
  .backimage01 .image {
    padding: 150px 0;
  }
}
@media screen and (min-width:961px) {
  .backimage01 {
    background-attachment: fixed;
  }
}

/* アクティビティ */
.activities .sectitlebox .sec_image {
  top: 0;
}
.activities .categoryarea {
  margin-top: 90px;
}
.activities .tag_list,
.activities .cat_list {
  flex-wrap: wrap;
  gap: 10px;
}
.activities .tag_list {
  margin-top: 10px;
}
.activities .tag_item,
.activities .cat_item {
  width: calc((100% - 60px)/7);
  box-sizing: border-box;
  transition: all .3s;
}
.activities .tag_item {
  background-color: var(--color2);
}
.activities .cat_item {
  background-color: var(--color3);
}
.activities .tag_item:hover {
  background-color: #1b1464;
}
.activities .cat_item:hover {
  background-color: #F15A22;
}
.activities .tag_item a,
.activities .cat_item a {
  font-size: 14px;
  color: #fff;
  padding: 10px;
  display: block;
}
.activities .listarea {
  padding-bottom: 80px;
}
.activities .listarea .list {
  flex-wrap: wrap;
  gap: 0 115px;
  padding: 0 57px;
  border-left: solid 1px #e2e2e2;
  border-right: solid 1px #e2e2e2;
}
.activities .listarea .item {
  width: calc((100% - 230px)/3);
  box-sizing: border-box;
  padding-top: 50px;
  position: relative;
}
.activities .listarea .item:nth-child(1),
.activities .listarea .item:nth-child(2),
.activities .listarea .item:nth-child(3) {
  padding-top: 0;
}
.activities .listarea .item::after {
  content: "";
  width: 1px;
  height: 100%;
  background-color: rgba(112, 112, 112, .2);
  display: block;
  position: absolute;
  top: 0;
  right: -57px;
}
.activities .listarea .item:nth-child(3n)::after {
  content: none;
}
.activities .listarea .item .pict {
  overflow: hidden;
}
.activities .listarea .item .pict img {
  width: 100%;
}
.activities .listarea .box {
  margin-top: 15px;
  margin-bottom: 10px;
}
.activities .listarea .box .item_title,
.activities .listarea .box .txt {
  transition: all .3s;
}
.activities .listarea .item a:hover .item_title,
.activities .listarea .item a:hover .txt {
  color: var(--color3);
}
.activities .listarea .box .item_title {
  font-size: 18px;
  margin-bottom: 10px;
}
.activities .listarea .box .txt {
  font-size: 14px;
  text-align: justify;
}
.activities .listarea .t_list {
  flex-wrap: wrap;
  gap: 5px;
}
.activities .listarea .t_item {
  font-size: 12px;
  color: #fff;
  background-color: var(--color3);
  padding: 2px 10px;
  display: block;
}
.activities .listarea .t_item.tag {
  background-color: var(--color2);
}
.activities .btn {
  width: 90%;
  max-width: 300px;
  margin: 90px auto 0;
  box-sizing: border-box;
}
.activities .btn a {
  line-height: 50px;
  color: #fff;
  background-color: var(--color2);
  display: block;
  position: relative;
  transition: all .3s;
}
.activities .btn:hover a {
  opacity: .75;
}
.activities .btn span {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  display: inline-flex;
  transition: all .3s;
}
.activities .btn:hover span {
  right: 10px;
}
@media screen and (max-width:960px) {
  .activities {
    background-color: var(--color5);
  }
  .activities .sectitlebox .sec_image {
    top: -20px;
  }
  .activities .categoryarea {
    margin-top: 35px;
  }
  .activities .listarea .list {
    gap: 0 40px;
    padding: 0 20px;
  }
  .activities .listarea .item {
    width: calc((100% - 80px)/3);
  }
  .activities .listarea .item::after {
    right: -20px;
  }
  .activities .tag_item,
  .activities .cat_item {
    width: calc((100% - 20px)/3);
  }
  .activities .btn {
    width: 100%;
    max-width: 260px;
  }
  .activities .btn a {
    font-size: 14px;
  }
}
@media screen and (max-width:768px) {
  .activities .listarea .list {
    gap: 50px;
  }
  .activities .listarea .item {
    width: 100%;
    padding-top: 0;
  }
  .activities .listarea .item::after {
    content: none;
  }
  .activities .btn {
    margin-top: 50px;
  }
}
@media screen and (max-width:480px) {
  .activities .tag_list,
  .activities .cat_list {
    gap: 5px;
  }
  .activities .tag_item,
  .activities .cat_item {
    width: calc((100% - 10px)/3);
  }
  .activities .tag_item a,
  .activities .cat_item a {
    padding: 5px 10px;
  }
  .activities .tag_list {
    margin-top: 5px;
  }
}

/* アバウト */
.about {
  background-image: url(../img/top/img_top24.jpg);
  background-repeat: no-repeat;
}
.about .titlebox {
  color: #fff;
  margin-bottom: 70px;
}
.about .titlebox .sub {
  font-size: 18px;
  margin-bottom: 10px;
}
.about .titlebox .sub::before {
  content: "";
  width: 100px;
  height: 1px;
  background-color: #fff;
  vertical-align: middle;
  margin-right: 10px;
  display: inline-block;
}
.about .titlebox .title {
  font-size: 40px;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.about .titlebox .txt_en {
  font-size: 190px;
  color: #b7b7b7;
  line-height: 1;
  mix-blend-mode: multiply;
  overflow: hidden;
}
.about .container .flex_inn {
  justify-content: space-between;
}
.about .container .txt {
  width: 65%;
  font-size: 20px;
  text-align: justify;
  line-height: 2.5;
  color: #fff;
  box-sizing: border-box;
}
.about .container .pict {
  width: 32%;
  box-sizing: border-box;
}
.about .boxarea {
  margin-top: 100px;
}
.about .boxarea .box {
  align-items: center;
  justify-content: space-between;
  gap: 100px;
  margin-bottom: 60px;
}
.about .boxarea .box:last-child {
  margin-bottom: 0;
}
.about .boxarea .txtbox {
  width: 65%;
  text-align: justify;
  color: var(--color2);
  line-height: 2;
  padding: 4%;
  background-color: var(--color5);
  box-sizing: border-box;
  position: relative;
}
.about .boxarea .pictbox {
  width: 35%;
  box-sizing: border-box;
}
.about .boxarea .b_name {
  font-size: 14px;
  color: #fff;
}
.about .support {
  margin-top: 100px;
}
.about .support_txt {
  font-size: 20px;
  line-height: 2.5;
  color: #fff;
}
.about .support_pict {
  margin-top: 50px;
  margin-bottom: 40px;
}
.about .support_pict a {
  background-color: #fff;
  display: inline-block;
}
.about .support_btn {
  width: 90%;
  max-width: 300px;
  margin: 0 auto;
  box-sizing: border-box;
}
.about .support_btn a {
  line-height: 50px;
  color: #fff;
  background-color: var(--color2);
  display: block;
  position: relative;
  transition: all .3s;
}
.about .support_btn:hover a {
  opacity: .75;
}
.about .support_btn span {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  display: inline-flex;
  transition: all .3s;
}
.about .support_btn:hover span {
  right: 10px;
}
@media screen and (max-width:960px) {
  .about {
    background: none;
    /* background-position: top center; */
    /* background-color: #2D194D; */
  }
  .about::after {
    content: "";
    width: 100%;
    height: 100%;
    background-image: url(../img/top/img_top24.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    z-index: -1;
  }
  .about .titlebox {
    margin-bottom: 30px;
  }
  .about .titlebox .sub {
    font-size: 11px;
  }
  .about .titlebox .title {
    font-size: 28px;
  }
  .about .titlebox .txt_en {
    font-size: 64px;
  }
  .about .container .flex_inn {
    flex-wrap: wrap;
    gap: 30px;
  }
  .about .container .txt,
  .about .container .pict {
    width: 100%;
  }
  .about .container .txt {
    font-size: 16px;
  }
  .about .container .pict {
    text-align: center;
  }
  .about .boxarea .box {
    flex-wrap: wrap;
    gap: 20px;
  }
  .about .boxarea .txtbox,
  .about .boxarea .pictbox {
    width: 100%;
  }
  .about .boxarea .txtbox {
    padding: 40px;
  }
  .about .boxarea .txtbox::after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 12px solid transparent;
    border-left: 12px solid transparent;
    border-top: 50px solid var(--color5);
    border-bottom: 0;
    position: absolute;
    bottom: -50px;
    left: 40%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
  }
  .about .boxarea .pictbox {
    text-align: center;
  }
  .about .support {
    margin-top: 60px;
  }
  .about .support_pict {
    margin-top: 40px;
  }
  .about .support_txt {
    font-size: 16px;
  }
}
@media screen and (min-width:961px) {
  .about {
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
  }
  .about .boxarea .box:nth-child(odd) .txtbox::after {
    content: "";
    width:0;
    height:0;
    border-style:solid;
    border-width: 25px 0 25px 100px;
    border-color: transparent transparent transparent var(--color5);
    position: absolute;
    top: 50%;
    right: -100px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
  }
  .about .boxarea .box:nth-child(even) .txtbox::after {
    content: "";
    width:0;
    height:0;
    border-style:solid;
    border-width: 25px 100px 25px 0;
    border-color: transparent var(--color5) transparent transparent;
    position: absolute;
    top: 50%;
    left: -100px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
  }
  .about .titlebox .txt_en {
    margin-top: -80px;
  }
}

/* パッケージ */
.package .sectitlebox::before {
  content: none;
}
.package .sectitlebox .title_inn {
  margin-top: 0;
}
.package .sectitlebox .sec_title {
  margin-bottom: 0;
}
.package .container .box {
  width: calc(((100vw - 1200px) / 2) + 1200px);
  align-items: flex-start;
  gap: 60px;
  box-sizing: border-box;
}
.package .container .childbox .box_title {
  font-size: 30px;
  font-weight: 500;
  color: var(--color2);
  margin-bottom: 50px;
}
.package .container .childbox .box_sub {
  font-size: 20px;
  margin-bottom: 30px;
}
.package .container .childbox .txt {
  text-align: justify;
  line-height: 1.75;
}
.package .container .childbox .btn {
  width: 90%;
  max-width: 300px;
  margin-top: 60px;
  box-sizing: border-box;
}
.package .container .childbox .btn a {
  line-height: 50px;
  color: #fff;
  background-color: var(--color2);
  display: block;
  position: relative;
  transition: all .3s;
}
.package .container .childbox .btn:hover a {
  opacity: .75;
}
.package .container .childbox .btn span {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  display: inline-flex;
  transition: all .3s;
}
.package .container .childbox .btn:hover span {
  right: 10px;
}
@media screen and (max-width:1350px) {
  .package .container .box {
    width: 95%;
  }
}
@media screen and (max-width:960px) {
  .package {
    background-color: var(--color5);
  }
  .package .sectitlebox {
    padding-top: 0;
    margin-bottom: 30px;
  }
  .package .sectitlebox .txt_en {
    margin-top: -30px;
  }
  .package .container .box {
    width: 100%;
    display: block;
  }
  .package .container .box .pict {
    margin-bottom: 30px;
  }
  .package .container .childbox {
    width: 90%;
    margin: 0 auto;
  }
  .package .container .childbox .box_title {
    font-size: 22px;
    margin-bottom: 35px;
  }
  .package .container .childbox .box_sub {
    font-size: 18px;
    line-height: 1.75;
    margin-bottom: 20px;
  }
  .package .container .childbox .btn {
    margin: 40px auto 0;
  }
}
@media screen and (min-width:961px) {
  .package .sectitlebox .txt_en {
    text-align: right;
    margin-top: -100px;
  }
  .package .container .pict {
    width: 55%;
    max-height: 450px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  .package .container .childbox {
    width: 40%;
    box-sizing: border-box;
  }
}

/* よくあるご質問 */
.faq {
  background-color: var(--color2);
}
.faq .titlebox {
  color: #fff;
  margin-bottom: 70px;
}
.faq .titlebox .sub {
  font-size: 18px;
  margin-bottom: 10px;
}
.faq .titlebox .sub::before {
  content: "";
  width: 100px;
  height: 1px;
  background-color: #fff;
  vertical-align: middle;
  margin-right: 10px;
  display: inline-block;
}
.faq .titlebox .title {
  font-size: 40px;
  font-weight: 500;
}
.faq .item {
  margin-bottom: 20px;
}
.faq .item:last-child {
  margin-bottom: 0;
}
.faq .item .q_box,
.faq .item .a_box {
  padding: 20px;
  padding-left: 0;
}
.faq .item .q_box {
  align-items: center;
  background-color: var(--color5);
  cursor: pointer;
  transition: all .3s;
  position: relative;
}
.faq .item .q_box:hover {
  background-color: var(--hr-color);
}
.faq .item .q_box::before,
.faq .item .q_box::after {
  content: "";
  width: 20px;
  height: 1px;
  position: absolute;
  top: 50%;
  right: 20px;
  background: var(--color1);
  transition: all .3s ease-in-out;
}
.faq .item .q_box::before {
  transform: rotate(90deg);
}
.faq .item .q_box.open::before {
  transform: rotate(180deg);
}
.faq .item .q_box.open::after {
  opacity: 0;
}
.faq .item .a_box {
  background-color: #fff;
  display: none;
}
.faq .item .a_box .flex_inn {
  align-items: center;
}
.faq .item .icon {
  width: 100px;
  min-width: 100px;
  font-size: 30px;
  line-height: 1;
  color: var(--color2);
  text-align: center;
  box-sizing: border-box;
}
.faq .item .a_box .icon {
  color: var(--color3);
}
.faq .item .txt {
  width: 85%;
  line-height: 1.75;
  text-align: justify;
  box-sizing: border-box;
}
.faq .item .txt a {
  color: var(--color2);
  text-decoration: underline;
}
.faq .pictbox {
  width: calc(((100vw - 1200px) / 2) + 1200px);
  box-sizing: border-box;
  margin-top: 70px;
}
.faq .pictbox img.imgsp {
  display: none;
}
@media screen and (max-width:1350px) {
  .faq .pictbox {
    width: 95%;
  }
}
@media screen and (max-width:960px) {
  .faq .titlebox {
    margin-bottom: 30px;
  }
  .faq .titlebox .sub {
    font-size: 11px;
  }
  .faq .titlebox .title {
    font-size: 28px;
  }
  .faq .pictbox {
    width: 100%;
    display: block;
  }
  .faq .item {
    margin-bottom: 10px;
  }
  .faq .item .icon {
    width: 60px;
    min-width: 60px;
  }
  .faq .item .q_box {
    padding-right: 60px;
  }
}
@media screen and (max-width:768px) {
  .faq .pictbox img.imgpc {
    display: none;
  }
  .faq .pictbox img.imgsp {
    display: block;
  }
}

/* Googleマップ */
.g_map {
  height: 700px;
}
.g_map iframe {
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
@media screen and (max-width:960px) {
  .g_map {
    height: 380px;
  }
}