@charset "UTF-8";
/*---------------------------------
common_overwrite
---------------------------------*/
html {
	scroll-behavior: smooth;
}
DIV#contentsTitle h1 {
	background-image: none;
	padding: 42px 0 0;
	font-size: 24px;
	width: 960px;
	margin: 0 auto;
	font-weight: bold;
	line-height: 150%;
	color: #2b2b2b;
}
body .honeymoon_contents {
	font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体" , "メイリオ", sans-serif !important;
	color: #212121 !important;
}
DIV#contents {
	padding: 0;
}
DIV#contents P {
	margin-bottom: 0;
}
DIV#mainBg,DIV#contents {
	width: 100% !important;
}
DIV#contents .honeymoon_contents a {
	color: #212121;
}
DIV#contents .mainColSizeContainer {
	width: 100%;
	margin: 0;
}

/*---------------------------------
common
---------------------------------*/
DIV#contents .honeymoon_contents DIV.contentsTitle h3 {
	font-family: 'Outfit', sans-serif;
	background-image: none;
	font-size: 75px;
	color:#212121;
	font-weight: 500;
	border-bottom: 0;
	line-height: 2.8rem;
	margin-top: 72px;
	padding: 20px 0;
}
DIV#contents .honeymoon_contents DIV.contentsTitle h3 span {
	font-size: 18px;
	font-weight: 500;
}
DIV#contents .honeymoon_contents a {
	opacity: 1;
	transition: all .3s;
	text-decoration: none;
}
DIV#contents .honeymoon_contents a:hover {
	opacity: 0.75;
}

/*---------------------------------
ページタイトル
---------------------------------*/
DIV#contents .honeymoon_contents h1 {
	color: #212121;
	font-size: 75px;
	font-weight: 600;
	font-family: "Outfit",sans-serif;
	line-height: 1;
	text-align: center;
	margin: 42px auto 2px;
}

/*---------------------------------
main
---------------------------------*/

	/* メインビジュアル swiper 設定 */
.honeymoon_main {
	background: linear-gradient(180deg, #fff 0%, #fff 40%, #CAE8E8 40%, #CAE8E8 100%);
	overflow: hidden;
}
.honeymoon_inner,
.honeymoon_swiper {
	width: 960px;
	margin: 0 auto;
}
.swiper-container {
	padding: 0 0 100px;
	position: relative;
}
.swiper-container .swiper-wrapper {
	padding: 0 0 40px;
}
.swiper-container .swiper-wrapper .swiper-slide {
	width: 594px;
	height: 415px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
.swiper-container .swiper-wrapper .swiper-slide div {
	overflow: hidden;
	width: 594px;
	height: 334px;
}
.swiper-container .swiper-wrapper .swiper-slide div img {
	object-fit: cover;
	width: 100%;
	height: auto;
}
.swiper-container .swiper-wrapper .swiper-slide p {
	position: absolute;
	background-color: #fff;
	border-radius: 5px;
	font-size: 18px;
	width: 484px;
	height: 60px;
	padding: 30px;
	left: 0;
	right: 0;
	bottom: -40px;
	margin: 0 auto;
	font-weight: bold;
}
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
	bottom: 40px;
	top: auto;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #5CBCBC;
}
.swiper-pagination-bullet {
	background-color: #fff;
	opacity: 1;
}

	/* オススメ記事バナー swiper 設定 */
.honeymoon_banner {
	overflow: hidden;
	margin-top: 100px;
}
DIV#contents .honeymoon_banner DIV.contentsTitle h3 {
	width: 960px;
	margin: 0 auto 40px;
}
.honeymoon_banner .honeymoon_inner,
.honeymoon_banner .honeymoon_swiper {
	margin: 0 auto;
	width: 100%;
}
.swiper-container-banner {
	padding: 0 0 68px;
	position: relative;
}
.swiper-container-banner .swiper-wrapper {
	width: 100%;
}
.swiper-container-banner .swiper-wrapper .swiper-slide {
	width: 652px;
	height: 326px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}
.swiper-container-banner .swiper-wrapper .swiper-slide a {
	overflow: hidden;
	width: 652px;
	height: 326px;
}
.swiper-container-banner .swiper-wrapper .swiper-slide img {
	object-fit: cover;
	width: 100%;
	height: auto;
}

.swiper-container-banner .swiper-horizontal>.swiper-pagination-bullets,
.swiper-container-banner .swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-container-banner .swiper-pagination-custom,
.swiper-container-banner .swiper-pagination-fraction {
	bottom: 0;
	top: auto;
}
.swiper-container-banner .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #51ADAD;
}
.swiper-container-banner .swiper-pagination-bullet {
	background-color: #C8C8C8;
	opacity: 1;
}

/*---------------------------------
category
---------------------------------*/
.honeymoon_category_list {
	display: flex;
	gap: 50px;
}
.honeymoon_category_list .category_overseas_resorts,
.honeymoon_category_list .category_domestic_resorts {
	width: 455px;
}
DIV#contents .honeymoon_category_list h4 {
	position: relative;
	font-size: 18px;
	border: none;
	background-image:none;
	color: #212121;
	text-align: center;
	padding: 10px 0 5px;
}
DIV#contents .honeymoon_category_list h4::before,
DIV#contents .honeymoon_category_list h4::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
}
DIV#contents .honeymoon_category_list h4::before {
	width: 98%;
	border: #A4A4A4 1px dashed;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: calc(50% + 1px);
	z-index: -1;
}
DIV#contents .honeymoon_category_list h4::after {
	min-width: 100px;
	width: 120px;
	height: 20px;
	background-color: #fff;
	z-index: -1;
}
.honeymoon_category_list ul {
	display: flex;
	flex-wrap: wrap;
	gap: 19px;
	margin: 0;
}
.honeymoon_category_list ul li {
	border: 1px solid #E1E1E1;
	width: 137px;
	height: 68px;
	text-align: center;
	border-radius: 3px;
	display: flex;
	flex-wrap: wrap;
	overflow: hidden;
	position: relative;
	align-items: center;
}
.honeymoon_category_list ul li.report {
	width: 453px;
	height: 88px;
}
.honeymoon_category_list ul li::before {
	position: absolute;
	content: "";
	background-color: #E3EFE6;
	transform: skewY(-6deg);
	width: 100%;
	height: 56px;
	z-index: -1;
	bottom: -36px;
}
.honeymoon_category_list ul li.report::before {
	bottom: -25px;
}
.category_overseas_resorts ul li::before {
	background-color: #CAE8E8;
}
.category_domestic_resorts ul li::before {
	background-color: #FFF7E4;
}
.honeymoon_category_list ul li.guest::before {
	background-color: #F7E8ED;
}
.honeymoon_category_list ul li.guest p span {
	border-radius: 100px;
	background-color: #F7E8ED;
	font-size: 0.8rem;
	padding: 0 4px;
}
.honeymoon_category_list ul li img,
.honeymoon_category_list ul li p,
.honeymoon_category_list ul li a {
	display: block;
	width: 100%;
}
.honeymoon_category_list ul li img {
	width: 49px;
	margin: 0 auto;
	padding:15px;
}
.honeymoon_category_list ul li a {
	font-size: 15px;
	text-decoration: none;
	color: #212121;
	font-weight: 500;
}
DIV#contents .honeymoon_category_list ul li a {
	align-items: center;
	display: flex;
	width: 100%;
	height: 100%;
}

/*---------------------------------
	.overseas_resorts
---------------------------------*/
.overseas_resorts {
	background-color: #CAE8E8;
}

/*---------------------------------
	.domestic_resorts
---------------------------------*/
.domestic_resorts {
	background-color: #FFF7E4;
}

/*---------------------------------
	.category_content
---------------------------------*/

.category_content {
	position: relative;
	margin-top: 120px;
	padding: 115px 0 50px;
}
.category_content .inner {
	width: 960px;
	margin: 0 auto;
}
DIV#contents .category_content DIV.contentsTitle h3 {
	position: absolute;
	top: -50px;
	margin-top: 0;
}
.category__body {
	display: none;
	background: #fff;
	padding: 40px 50px
}
.category_title {
	text-align: center;
	padding-bottom: 42px;
	font-weight: bold;
	font-size: 22px;
}
.category_title img {
	display: block;
	margin: 0 auto 10px;
}

/*---------------------------------
	.honeymoon_featured
	.honeymoon_news
---------------------------------*/
.honeymoon_featured, .honeymoon_news {
	padding: 50px 0 100px;
}
.honeymoon_featured .inner
, .honeymoon_news .inner {
	border-radius: 5px;
	position: relative;
	background-color: #fff;
	width: 880px;
	margin: 0 auto;
	padding: 115px 40px 50px;
}
DIV#contents .honeymoon_contents .honeymoon_featured .inner DIV.contentsTitle h3,
DIV#contents .honeymoon_contents .honeymoon_news .inner DIV.contentsTitle h3 {
	position: absolute;
	top: -50px;
	margin-top: 0;
}
.honeymoon_featured .inner ul {
	display: flex;
	gap: 35px;
	flex-wrap: wrap;
	margin: 0;
}
.honeymoon_news .inner ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0;
}
.honeymoon_featured .inner ul li {
	width: 270px;
}
.honeymoon_news .inner ul li {
	width: 194px;
}
.honeymoon_featured .inner ul li img {
	object-fit: cover;
	width: 270px;
	height: 147px;
	border-radius: 5px;
}
.honeymoon_news .inner ul li img {
	object-fit: cover;
	width: 194px;
	height: 105px;
	border-radius: 5px;
}
.honeymoon_featured .inner ul li p,
.honeymoon_news .inner ul li p {
	padding: 20px 0 0;
	font-size: 15px;
	line-height: 1.5;
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
}
.btn_link_area {
	display: flex;
	gap: 45px;
	justify-content: center;
	margin-top: 70px;
}
a.btn_link {
	width: 456px;
	position: relative;
	border-radius: 40px;
	background: #fff;
	border: 1px solid #212121;
	font-size: 1.0rem;
	color: #212121;
	text-align: center;
	padding: 18px;
	font-weight: bold;
}
a.btn_link:hover {
	background-color: #F4F4F4;
}
a.btn_link span img {
	vertical-align: middle;
}
a.btn_link::after {
	content:"";
	color: #333;
	line-height: 1;
	width: 8px;
	height: 8px;
	border:2px solid currentColor;
	border-left: 0;
	border-bottom: 0;
	box-sizing: border-box;
	transform: translateX(-25%) rotate(45deg);
	position: absolute;
	right: 20px;
	top: calc(50% - 4px);
}

/*---------- 海外リゾート挙式をお探しの方はこちら　ボタン ----------*/
DIV#contents .overseas_resorts_btn a.btn_link {
	border: 1px solid #5CBCBC;
	color: #51ADAD;
}
DIV#contents .overseas_resorts_btn a.btn_link::after {
	color: #51ADAD;
}

/*---------- 国内リゾート挙式をお探しの方はこちら　ボタン ----------*/
DIV#contents .domestic_resorts_btn a.btn_link {
	border: 1px solid #D8B256;
	color: #C9A13F;
}
DIV#contents .domestic_resorts_btn a.btn_link::after {
	color: #C9A13F;
}


/*---------------------------------
honeymoon_category_content
└accordion
---------------------------------*/
/*.accordion-wrap {
	margin-bottom:140px;
}*/
.accordion-dlist {
	border-radius: 5px;
	background: #fff;
	margin-bottom: 50px;
	box-shadow: 0px 3px 12px rgba(0, 0, 0, 0.1);
}
DIV#contents .honeymoon_contents .accordion-desc ul {
	margin: 0 auto;
}
.accordion-desc ul li.summary_item {
	align-items: center;
	display: flex;
	flex-direction: row;
	line-height: 1.5;
	font-size: 15px;
	margin-bottom: 20px;
}
.accordion-desc ul li.summary_item img {
	min-width: 200px;
	max-width: 200px;
	height: 200px;
	border-radius: 3px;
	margin-right: 20px;
}
.accordion-desc ul li.summary_item a .link_text {
	position: relative;
	text-align: right;
	text-decoration: underline;
	margin-top: 30px;
	padding-right: 24px;
}
.accordion-desc ul li.summary_item a:hover .link_text {
	text-decoration: none;
}
.accordion-desc ul li.summary_item a .link_text::after {
	position: absolute;
	top: 50%;
	right: 12px;
	bottom: initial;
	left: initial;
	content: "";
	width: 7px;
	height: 7px;
	border-top: 1px solid #212121;
	border-right: 1px solid #212121;
	transform: translateY(-50%) rotate(45deg);
}
.accordion-desc ul li.content_item {
	margin-bottom: 10px;
}
.accordion-desc ul li.content_item a {
	align-items: center;
	display: flex;
	flex-direction: row;
	line-height: 1.5;
	font-size: 15px;
}
.accordion-desc ul li.content_item a img {
	object-fit: cover;
	min-width: 130px;
	max-width: 130px;
	height: 72px;
	object-position: top;
	border-radius: 3px;
	margin-right: 20px;
}
.accordion-desc ul li.content_item a p {
	text-decoration: underline;
}
.accordion-desc ul li.content_item a:hover p {
	text-decoration: none;
}
.accordion-subtitle {
	font-size: 18px;
	font-weight: bold;
	position: relative;
}
.accordion-subtitle span {
	border-radius: 100px;
	background-color: #F7E8ED;
	font-size: 0.8rem;
	padding: 0 4px;
}
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc .btn_link_area {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 20px;
}


/*---------- 海外リゾートはこちら　ボタン ----------*/
DIV#contents .honeymoon_contents .overseas_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link {
	background: #51ADAD;
	border: 1px solid #51ADAD;
}
DIV#contents .honeymoon_contents .overseas_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover {
	color:#51ADAD;
}
DIV#contents .honeymoon_contents .overseas_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover::after {
	border: 2px solid #51ADAD;
	border-left: transparent;
	border-bottom: transparent;
}


/*---------- 国内リゾートはこちら　ボタン ----------*/
DIV#contents .honeymoon_contents .domestic_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link {
	background: #D8B256;
	border: 1px solid #D8B256;
}
DIV#contents .honeymoon_contents .domestic_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover {
	color:#D8B256;
}
DIV#contents .honeymoon_contents .domestic_resorts .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover::after {
	border: 2px solid #D8B256;
	border-left: transparent;
	border-bottom: transparent;
}


/*---------- 海外・国内リゾートボタン共通 ----------*/
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc a.btn_link {
	width: 100%;
	display: block;
	font-weight: bold;
	color: #fff;
	padding: 10px;
}
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover {
	background-color: #fff;
}
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover::after {
	border-left: transparent;
	border-bottom: transparent;
	opacity: 1;
}
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc a.btn_link::after {
	border: 2px solid #fff;
	border-left: transparent;
	border-bottom: transparent;
}
DIV#contents .honeymoon_contents .accordion-wrap .accordion-dlist .accordion-desc a.btn_link:hover:after {
	border-left: transparent;
	border-bottom: transparent;
}

@media screen and (min-width: 768px) {
	.accordion-dlist{
		display: flex;
		align-items: center;
		padding: 50px 40px;
		gap: 36px;
	}
	.accordion-desc{
		border-left: 1px solid #A4A4A4;
		padding-left: 40px;
		width: 620px;
	}
	.accordion-term {
		min-width: 196px;
		text-align: center;
	}
	.accordion-term img {
		display: block;
		margin: 0 auto 15px;
	}
}


/*---------------------------------
	.floating
---------------------------------*/
.floating.is-hidden {
  display: none;
}
.floating .honeymoon_inner{
  position: relative;
  text-align: right;
}
.floating .honeymoon_inner .scroll_top {
  position: fixed;
  bottom: 20px;
  z-index: 1000;
}
.bg_obj_position_top {
  object-position: top !important;
}
.bg_obj_position_bottom {
  object-position: bottom !important;
}
