@charset "UTF-8";
/* CSS Document */
/* 共通Mixins
----------------*/
/* common
-----------------------------*/
#language {
  display: none;
}
#contents {
  padding-bottom: 0;
  margin-bottom: 0;
  /* margin-top: 54px; */
}
#contInner {
  width: 100%;
  margin: 0;
}
#contentsArea {
  width: 100%;
}
#wrapper {
  overflow: visible;
}
#wrapper #main {
  padding-top: 0;
}
#main {
  margin-bottom: 0;
}
#wrapper .pc_appear {
  display: none;
}
#wrapper .sp_appear {
  display: block;
}
#spMenuWrap {
  display: block;
}
/* ----------------------------
  content
------------------------------*/
/* --------------------
 共通
----------------------*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,500,600&display=swap');

.happiness {
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'メイリオ', 'MS PGothic', sans-serif;
}
.happiness *,
.happiness *:before,
.happiness *:after {
  box-sizing: border-box;
}
.happiness_contents {
  padding: 10.4% 0 14.4% 0;
}
.happiness_title {
  width: 92.5%;
  margin: -7.46% auto 0;
}
.happiness_title_lead {
  width: 84.66%;
  margin: 2.9% auto 0;
}
.section_inner {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  padding-top: 40px;
}

/* mainvisual
------------------------*/


/* nav
------------------------*/
.nav {
  width: 92%;
  margin: 0 auto;
  padding: 92% 0 4.8% 0;
}
.nav .pagenav {
  margin-bottom: 4%;
}
.nav .pagenav_item {
  width: 100%;
  box-sizing: border-box;
  margin-left: 0;
  margin-top: 2%;
}
.nav .pagenav_item:first-child{
  margin-top: 0;
}

/* lead */
.lead-area-wrapper {
  display: block;
  padding-bottom: 0;
}
.lead-area-inner {
  width: 100%;
  padding: 28px 0 0;
}
.lead-area-inner .lead {
  font-size: 20px;
  /* padding-top: 24%; */
  line-height: 30px;
}
.lead-area-inner .lead-info {
  font-size: 14px;
  line-height: calc(22/14);
  padding: 3% 0;
  text-align: center;
}
.lead-area-wrapper li:first-child {
  /* max-width: 295px; */
  margin: 0 auto 45px;
}
.lead-area-wrapper li:last-child {
  max-width: 100%;
}
.lead-area .nonlead {
  /* padding-bottom: 0; */
}
/* scroll-btn */
.scroll_btn_outer {
  padding: 0 0 40px;
}
#scroll-btn {
	width: 20px;
  top: 20px;
	padding-bottom: 1%;
}
.scroll-btn {
  font-size: 18px;
  margin-top: 1px;
}
#scroll-btn::after {
	width: 2px;
	height: 40px;
	transform: translateX(-50%);
  left: 0;
	top: 0;
}
#scroll-btn::before {
	width: 24px;
	height: 24px;
  transform: translateX(-50%);
	left: 0px;
	bottom: -8px;
	animation: top_arrow infinite 5s;
}
@keyframes top_arrow {
  0%   { transform: translate(-50%, 0);}
  50%   { transform: translate(-50%, 40px);}
  100%  { transform: translate(-50%, 0);}
}
@-webkit-keyframes top_arrow {
  0%   { -webkit-transform: translate(-50%, 0);}
  50%   { -webkit-transform: translate(-50%, 40px);}
  100%  { -webkit-transform: translate(-50%, 0);}
}

/* -----------------------------------
check_btn
-------------------------------------*/
.check_btn{
  padding: 0 0 9.5%;
  /* max-width: 255px; */
}
/* .check_btn img:hover{
  opacity: 0.7;
  transition: .5s;
} */
.check_btn a {
  width: 92%;
  padding: 20px 0 0;
}

#feature .check_btn a{
  margin-top: 0px;
  padding-top: 8px;
}

#wrapper .btn-parts-upper {
  margin-bottom: 8px;
  width: 66%;
}

#access .check_btn {
  padding-bottom: 0;
}
/* -----------------------------------
section_title
-------------------------------------*/
.feature_title,
.facility_title,
.event_title {
  padding: 3% 0 0;
}
.recommend_information_title {
  padding: 3% 0 3%;
}
.mall_information_title{
  padding: 4% 10%;
}
.section-ttl {
  padding-top: 0;
}
#feature .section-ttl,
#facility .section-ttl,
#special_movie .section-ttl,
#event .section-ttl,
#sale .section-ttl,
#recomennd_information .section-ttl,
#access .section-ttl {
  width: 90%;
  margin: 0 auto;
}
#access .section-ttl {
  margin-bottom: 32px;
}
.intro .feature_sub_title,
.intro .facility_sub_title {
  font-size: 14px;
  line-height: calc(22/14);
}
/* -----------------------------------
各sectionの影
-------------------------------------*/
/* .section-shadow {
  position: relative;
  border-radius: 16px 16px 16px 16px;
  box-shadow: 0 6px 16px -10px;
}
.lead-area-all-wrapper.section-shadow {
  z-index: 10;
}
.feature_area_outer_frame.section-shadow {
  border-radius: 16px;
  z-index: 11;
  margin-top: -35px;
  padding-top: 70px;
}
.event_area_outer_frame.section-shadow {
  z-index: 8;
  margin-top: -35px;
  padding-top: 70px;
}
.sale_area_outer_frame.section-shadow {
  z-index: 7;
  margin-top: -35px;
  padding-top: 70px;
}
.facility_area_outer_frame.section-shadow {
  z-index: 6;
  margin-top: -35px;
  padding-top: 70px;
}
.special-movie_area_outer_frame.section-shadow {
  z-index: 5;
  margin-top: -35px;
  padding-top: 70px;
}
.recomennd_information_area_outer_frame.section-shadow {
  z-index: 4;
  margin-top: -35px;
  padding-top: 70px;
}
.access_area_outer_frame.section-shadow {
  position: relative;
  z-index: 3;
  margin-top: -35px;
  padding-top: 35px;
  border-radius: 0;
  box-shadow: none;
}
.contents-bg {
  border-radius: 0 0 16px 16px;
}
#wrapper .lead-area-wrapper img {
  width: 100%;
  border-radius: 0 0 16px 16px;
}
.lead-area-wrapper li:first-child {
  max-width: 100%;
  margin: 0 auto;
  padding-bottom: 40px;
  border-radius: 0 0 16px 16px;
  position: relative;
  z-index: 11;
  background-color: #78C398;
}
.lead-area-wrapper li:last-child {
  position: relative;
  z-index: 10;
  top: -10px;
} */
/* -----------------------------------
各sectionの背景画像
-------------------------------------*/
/* .feature_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents1-1_sp.png'), url('../img/sp/img-bg-contents1-2_sp.png');
  background-position: center 10px, center bottom;
  background-size: 100%;
}
.event_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents2-1_sp.png'), url('../img/sp/img-bg-contents2-2_sp.png'), url('../img/sp/img-bg-contents2-3_sp.png');
  background-position: center 44px, right center, left center;
  background-size: 100% auto, 16% auto, 40% auto;
}
.sale_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents3-1_sp.png'), url('../img/sp/img-bg-contents3-2_sp.png'), url('../img/sp/img-bg-contents3-3_sp.png');
  background-position: center 38px, left bottom, right center;
  background-size: 100% auto, 46% auto, 49% auto;
}
.recomennd_information_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents4-1_sp.png'), url('../img/sp/img-bg-contents4-2_sp.png');
  background-position: center 40px, center bottom;
  background-size: 100% auto, 100% auto;
}
.access_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents5-1_sp.png');
  background-position: center bottom;
  background-size: 100%;
}
.facility_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents6-3_sp.png'), url('../img/sp/img-bg-contents6-1_sp.png'), url('../img/sp/img-bg-contents6-2_sp.png');
  background-position: left top 18%, left top 55%, right top 15%;
  background-size: 26% auto, 14% auto, 35% auto;
}
.special-movie_area_outer_frame {
  background-image: url('../img/sp/img-bg-contents7-1_sp.png'), url('../img/sp/img-bg-contents7-2_sp.png');
  background-position: center 10px, right bottom;
  background-size: 100%, 46%;
} */

/* -----------------------------------
large_contents
-------------------------------------*/
.large_contents {
  padding-bottom: 4%;
}

/* -----------------------------------
Feature
-------------------------------------*/
#feature .section_inner.feature-ttl-top {
  padding-top: 46px;
}
#feature .section_inner.feature-ttl-bottom {
  padding-top: 6%;
}
#feature #swiper_container {
  padding: 6% 0;
}
.feature_title {
  font-size: 3.1em;
  text-align: center;
  font-weight: bold;
}

.recommend_feature_inner {
  margin: 0 auto;
  position: relative;
}
.recommend_feature_inner .recommend_information_arrow {
  position: absolute;
  bottom: 0;
  right: 0;
}
.recommend_feature_inner .img_txt {
  font-size: 1.3em;
  padding: 5%;
}
.recommend_feature_inner .recommend_information_shopname{
  font-size: 1em;
  font-size: 3.4vw;
}
.recommend_feature .swiper-slide {
  padding-left: 2%;
}

/* スライドが1の場合 */
.recommend_feature .swiper-slide.case-sp-slidecount1 {
  padding-left: 0;
  width: 98% !important;
}
.recommend_feature .sp-swiper-option.sp-swiper-option-display-none {
  opacity: 0;
}


/* -----------------------------------
facility
-------------------------------------*/
#facility .section_inner.facility-ttl-top {
  padding-top: 46px;
}
#facility .section_inner.facility-ttl-bottom {
  padding-top: 6%;
}
#facility #swiper_container {
  margin: 6% 0;
}
.facility_title {
  font-size: 3.1em;
  text-align: center;
  font-weight: bold;
}
#facility .item-inner {
  height: auto;
}
.recommend_facility_inner {
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
}
.recommend_facility_inner .recommend_information_arrow {
  position: absolute;
  bottom: 0;
  right: 0;
}
.recommend_facility_inner .img_txt {
  font-size: 1.3em;
  padding: 5%;
}
.recommend_facility_inner .recommend_information_shopname{
  font-size: 1em;
  font-size: 3.4vw;
}
.recommend_facility .swiper-wrapper {
  flex-wrap: nowrap;
}
.recommend_facility .swiper-slide {
  width: 100%;
  padding-left: 2%;
}

/* スライドが1の場合 */
.recommend_facility .swiper-slide.case-sp-slidecount1 {
  padding-left: 0;
  width: 98% !important;
}
.recommend_facility .sp-swiper-option.sp-swiper-option-display-none {
  opacity: 0;
}

/* recommend
-------------------------------*/
.recommend_feature,
.recommend_facility,
.recommend_event {
  width: 100%;
  padding: 0;
}

/* intro
-------------------------*/
.intro p {
  margin-bottom: 8%;
  font-size: 5.1vw;
}

/* event
-------------------------*/
.recommend_event_inner {
  position: relative;
  z-index: 2;
  padding-left: 20px;
  padding-right: 20px;
}
#wrapper .recommend_event_list {
  width: 96%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#wrapper .recommend_event_item:first-child .more{
  padding-top: 0;
}
.recommend_event_item {
  width: 100%;
  margin-bottom: 6%;
  text-align: left;
}
.recommend_event_item .item-inner {
  height: auto;
}
.recommend_event_item dl{
  padding: 0 1%;
}
.recommend_event_title {
  font-size: 1.125rem;
  font-weight: bold;
  padding-bottom: 3%;
}
.recommend_event_detail {
  font-size: 0.775rem;
  line-height: 1.5;
  padding-left: 1em;
  text-indent: -1em;
}
.recommend_event .event_btn {
  width: 28%;
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
}
.recommend_event .event_btn a {
  width: 100%;
  padding: 7% 0;
  position: relative;
  background: #D8005C;
  color: #fff;
}
.recommend_event .event_btn a:before {
  position: absolute;
  content: '';
  width: 6px;
  height: 6px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 50%;
  right: 6%;
}
.recommend_event .event_btn:hover {
  opacity: 0.7;
}
#event .check_btn {
  width: 90%;
  flex-wrap: wrap;
}
#event .check_btn a {
  margin-bottom: 15px;
}
#event .check_btn a:last-child {
  margin-bottom: 0;
}
#event .check_btn a:nth-child(2n) {
  margin-left: 0;
}
.event_area .item-inner {
  margin-bottom: 0;
}
.recommend_event .section_inner {
  padding-top: 20px;
}

/* recomennd_information
------------------------------*/
.recommend_information_inner {
    position: relative;
    z-index: 2;
    padding: 0 20px;
}
.recommend_information_list {
  justify-content: space-between;
}
.recommend_information_list li {
  padding: 0 2% 6%;
}
#wrapper .recommend_information_list li img {
  width: 100%;
}
/* 奇数番目を45% */
.recommend_information_list li:nth-child(odd) {
  width: 49%;
}
/* 偶数番目を45% */
.recommend_information_list li:nth-child(even) {
  width: 49%;
}
/* liの最初の要素であり、奇数番目である場合 */
.recommend_information_list li:first-child:nth-last-child(odd) {
  width: 100%;
}

/* campaign
------------------------------*/
.campaign_inner {
  position: relative;
  z-index: 2;
}

.campaign_list li {
padding: 0 2% 6%;
}
#wrapper .campaign_list li img {
width: 100%;
}
/* 奇数番目を45% */
.campaign_list li:nth-child(odd) {
width: 49%;
}
/* 偶数番目を45% */
.campaign_list li:nth-child(even) {
width: 49%;
}
/* liの最初の要素であり、奇数番目である場合 */
.campaign_list li:first-child:nth-last-child(odd) {
width: 100%;
}
.campaign_list {
  justify-content: space-between;
  padding: 0 2%;
  }
/* mall_information
-------------------------------*/
.mall_information_area,
.special_feature_area,
.special_facility_area {
  width: 100%;
}
.mall_information_area.large_contents,
.special_feature_area.large_contents,
.special_facility_area.large_contents {
  background: #fff;
}
.info-item img {
  transform: none;
}

/* swiper
------------------------------*/
.swiper_nav {
  width: 100%;
  position: absolute;
  margin-top: 0;
  top: 30%;
  left: 0;
  right: 0
}
.swiper-container {
  width: 100%;
  position: relative;
  overflow: visible;
}
.swiper-wrapper {
  width: 100%;
  flex-wrap: none;
}
.swiper-slide a {
  display: block;
  text-decoration: none;
  cursor: pointer;
}
.swiper-slide a:hover .photo {
  transition: 0.5s;
  opacity: 0.7;
  background: #000;
}
.swiper-button-prev,
.swiper-button-next {
  background: url(../img/img-arrow.png) no-repeat center center;
  background-size: contain;
  width: 52px !important;
  height: 40px !important;
  margin-top: 0 !important;
  top: 19px !important;
  position: absolute !important;
  display: block !important;
  z-index: 999;
  transition: 0.3s cubic-bezier(0.13, 0.78, 0.38, 0.98);
}
.swiper-button-prev:hover,
.swiper-button-prev {
  left: 10%;
  right: auto;
}
.swiper-button-next {
  right: 10%;
  left: auto;
  transform: scale(-1, 1);
}
.swiper-button-next:hover {
  opacity: 0.7;
}
.js-swiper-navigation {
  width: 75.5%;
  margin: 52px auto 0;
}
.js-swiper-navigation .thumb {
  transition: 0.3s cubic-bezier(0.13, 0.78, 0.38, 0.98);
}
.js-swiper-navigation .thumb:hover {
  border: 3px solid #09961a;
  cursor: pointer;
}
.js-swiper-navigation .swiper-slide-active {
  border: 3px solid #09961a;
}
.swiper-pagination {
  display: block;
  position: relative !important;
  padding: 11% 0 7.5%;
  font-weight: bold;
}
.swiper-feature-pagination {
  font-size: 20px;
  color: #000;
}
.swiper-facility-pagination {
  font-size: 20px;
  color: #000;
}
#facility .swiper-wrapper {
  justify-content: unset;
}
.swiper-pagination-bullet {
  width: 14px !important;
  height: 14px !important;
  background-image: none !important;
  background-color: #353535 !important;
  border-radius: 50% !important;
  margin: 0 5px;
}
.swiper-pagination-bullet:after {
  border-radius: 50%;
  border: none !important
}
.swiper-pagination-bullet-active {
  background-color: #E52E8A !important
}
.swiper-event-pagination {
  display: none;
}
.recommend_event .swiper-event-button-prev,
.recommend_event .swiper-event-button-next,
.recommend_event .swiper-event-pagination {
  display: none;
}
@media screen and (max-width: 1000px) {
  .js-swiper-information-contents {
    width: 70%;
  }
}
@media screen and (max-width: 520px) {
  .js-swiper-information-contents {
    width: 100%;
  }
}
.swiper_event_nav {
  display: none !important;
}

/* ------------------------
 remordal
 -------------------------*/
/* Close button */
.remodal_close {
  position: absolute;
  bottom: 0;
  right: 0;
  display: block;
  overflow: visible;
  width: 70px;
  height: 70px;
  margin: 0;
  padding: 0;
  cursor: pointer;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
  text-decoration: none;
  color: #000;
  border: 0;
  outline: 0;
  background: 0 0;
}
.remodal_close:before {
  width: 70px;
  height: 70px;
  content: '';
  display: block;
  background: url(../img/btn-modal_close.png) no-repeat center center;
  background-size: contain;
  top: 0;
  right: 0;
  float: right;
}
/* remodal contents */
.remodal.remodal_wrap {
  max-width: 98.0625%;
  padding: 0.89% 4.52%;
}
.remodal_inner {
  text-align: left;
}
.remodal_inner .modal_iteminfo {
  width: 100%;
  margin-top: 6.2%;
}
.remodal_inner .modal_iteminfo_image {
  width: 100%;
  margin-bottom: 10px;
}
.remodal_inner .modal_iteminfo_image img {
  width: 100%;
  height: auto;
}
.remodal_inner .modal_iteminfo_text {
  width: 100%;
  margin: 0 auto 13px;
  line-height: 1.5;
}
.remodal_inner .modal_iteminfo_text .coordinate{
  padding-left: 1em;
  text-indent: -1em;
}
.remodal_inner .modal_iteminfo_text .item_theme{
  font-size: 17px;
  color: #24acde;
  font-weight: bold;
}
.remodal_inner .modal_iteminfo_text .item_point_title {
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: bold;
}
.remodal_inner .modal_iteminfo .modal_shopinfo_area dl{
  width: 100%;
  display:block;
}
.remodal_inner .modal_iteminfo .modal_shopinfo_area dt{
  display:block;
  width: 50%;
  color: #fff;
  margin-bottom: 10px;
  text-align: center;
  padding: 5px 0 5px 0;
  border: 1px solid #e4e4e4c4;
}
.remodal_inner .modal_iteminfo .modal_shopinfo_area .shop_floor {
  text-align: center;
  display:inline-block;
  padding: 10px 5px;
  background: #E52E8A;
  margin-bottom: 10px;
  color: #fff;
  font-weight: bold;
  font-size: 1.5em;
  width: 10%;
}
.remodal_inner .modal_iteminfo .modal_shopinfo_area .shop_name {
  text-align: left;
  display: inline-block;
  padding-left: 10px;
  margin-bottom: 10px;
  color: #000;
  font-weight: bold;
  font-size: 1.5em;
  width: 75%;
}

/* pagetopボタン */
.float_btn_area {
  position: fixed;
  width: 100px;
  right: 7px;
  bottom: 41px;
  z-index: 100;
}
.float_btn_item  {
  margin-bottom: 10px;
}
.float_btn_item:last-child {
  margin-bottom: 0;
}
.page_top_nav {
  width: 70px;
  margin-left: auto;
  margin-right: auto;
}

.pc-appear {
  display: none;
}
.sp-appear {
  display: block;
}

.item-inner {
  height: 144px;
}
#wrapper .more {
  display: none;
}
.contents-item-shadow {
  padding: 5%;
}
.contents-item {
  transform: none;
}

/* 詳しく見るボタン */
.more-wrapper {
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
}
#wrapper .more-wrapper .item-img {
  display: inline-block;
  width: 48%;
  transform: none;
}
#wrapper .more-wrapper a {
  width: 100%;
  /* transform: none; */
}
#wrapper .more-wrapper .sp-more-img img {
  width: 82%;
  margin-right: 2%;
}
/* .recommend_event_list li:first-child .more-wrapper {
  display: block;
} */
/* .recommend_event_list li:first-child .more-wrapper a {
  display: none;
} */
/* #wrapper .recommend_event_list li:first-child .more-wrapper .item-img {
  width: 100%;
} */
/* #wrapper .recommend_event_list li:first-child .more {
  display: block;
} */
#wrapper .more-wrapper .sp-more-img {
  display: block;
}
/* #wrapper .recommend_event_list li:first-child .more-wrapper .sp-more-img {
  display: none;
} */

/* footer周りの調整 */
footer .container {
  border-top: none;
}
footer .logo {
  display: none;
}

#wrapper .sp-more-img {
  opacity: 0;
  transform: translateX(-20px);
  transition: opacity 0.8s ease-in-out, transform 0.8s ease-in-out;
}
#wrapper .sp-more-img.visible {
  opacity: 1;
  transform: translateX(0);
}

.youtube {
  width: min(1120px, 90%);
  margin: 0 auto;
  border: 1px solid #fff;
}

/* contact area */
.contact_area.large_contents {
  padding-bottom: 9%;
}
.contact_inner {
  width: 92%;
}
/* info */
.recomennd_information_area.large_contents {
  padding-bottom: 10%;
}
/* sale */
.sale_inner {
  padding: 21px 20px 37px;
}
/* access */
#access .section_inner {
  padding: 60px 20px 0;
}
.access_inner {
  padding: 50px 0px;
}
.access_lists {
  padding: 0 20px;
  display: block;
}
.access_lists_left,
.access_lists_right  {
  width: 100%;
}
.access_lists_ttl {
  font-size: 18px;
  line-height: calc(22/18);
  text-align: center;
}
.access_lists_disc {
  font-size: 14px;
  line-height: calc(22/14);
}
.access_lists_disc {
  padding: 16px 20px;
}
.access_lists_left_content3 .access_lists_disc{
  text-align: center;
  margin-bottom: 40px;
}

/* map */
.map-area {
  height: auto;
}
.map-area iframe {
  height: 330px;
}

.check_btn {
  width: 80%;
}

.update-text {
  font-size: 20px;
  color: #fff;
  letter-spacing: 1px;
}

.recommend_movie {
  margin: 12% auto;
}

.facility_map {
  margin: 29px auto 40px;
}
.facility_tabitem {
  font-size: 1.125rem;
  padding: 8.25px 20px;
}