@charset "UTF-8";
/* CSS Document */
/* 共通Mixins
----------------*/
/* common
-----------------------------*/
/* body::before {
  background-image: url(../img/sp/bg.png);
} */
#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;
}

/* 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-inner {
  width: 90%;
  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: 30px;
  padding: 3% 0 40px;
}
.lead-area .nonlead {
  /* padding-bottom: 0; */
}
/* scroll-btn */
.scroll_btn_outer {
  padding: 0 0 70px;
}
#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: 10px;
	height: 10px;
  transform: translateX(-50%);
	left: 0px;
	bottom: 0;
	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%;
}
.check_btn img:hover{
  opacity: 0.7;
  transition: .5s;
}
.check_btn a {
  width: 92%;
  padding: 5% 0;
}
#feature .check_btn,
#feature .check_btn a {
  padding-top: 0;
}
/* -----------------------------------
section_title
-------------------------------------*/
.feature_title,
.event_title,
.recommend_facility_title,
.recommend_information_title {
  padding: 3% 0 3%;
}
.mall_information_title{
  padding: 4% 10%;
}

/* -----------------------------------
Feature
-------------------------------------*/

.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;
}

/* recommend
-------------------------------*/
.recommend_feature,
.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;
}
#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;
}

/* recomennd_facility
------------------------------*/
.recommend_facility {
  padding-top: 4%;
}
.recommend_facility_inner {
  position: relative;
  z-index: 2;
  padding: 0 2%;
}
.recommend_facility_list {
display: block;
/* justify-content: space-between; */
padding: 0;
}
.recommend_facility_list li {
padding: 0 2% 40px;
width: 100%;
}
#wrapper .recommend_facility_list li img {
width: 100%;
}

/* recomennd_information
------------------------------*/
.recommend_information {
  padding-top: 4%;
}
.recommend_information_inner {
    position: relative;
    z-index: 2;
    padding: 0 2%;
}
.recommend_information_list {
  display: flex;
  justify-content: space-between;
  padding: 0;
  gap: 0;
}
.recommend_information_list li {
  padding: 0 2% 40px;
  width: 100%;
}
#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%;
}

/* mall_information
-------------------------------*/
.mall_information_area {
  width: 100%;
  margin: 0 auto;
}
.mall_information_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: 98%;
  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;
  color: #000;
}
.swiper-feature-pagination {
  font-size: 20px;
}
.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ボタン */

.page_top_nav {
  display: none;
  width: 100px;
  position: fixed;
  right: 7px;
  bottom: 40px;
  z-index: 3;
}

#wrapper .btn_pc_top img {
width: 70px;
height: 70px;
}

#wrapper .btn_web_flyer {
margin-top: 10px;
display: block;
}

#wrapper .btn_web_flyer img {
width: 100px;
height: 100px;
}



.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);
}

/* 施設案内 */
.info-item-ttl {
  text-align: left;
  margin-top: 20px;
}

/* special movie */
#special_movie .youtube {
  margin: 20px auto 0;
  width: 90%;
  padding-bottom: 1.25%;
  position: relative;
  text-align: center;
}

#special_movie .youtube_inner {
  position: relative;
  margin: 0 auto;
}

#special_movie .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}