@charset "UTF-8";
/*=======================================================
下層ページ共通
=======================================================*/
/*ドロップシャドウ*/
.main__title {
	filter: drop-shadow(0 4px 4px black);
}
/*境内地図モーダル背景*/
.page-access .fancybox__content,
.page-hatsumiyamairi .fancybox__content,
.page-shichigosan .fancybox__content {
	background: #fff!important;
}
/*----------------------------------------------
FVヘッダー
---------------------------------------------- */
.fv__header {
    position: relative;
    margin-bottom: 50px;
}
.fv__header .fv__title-wrapper {
    display: flex; 
    align-items: center; 
    justify-content: center;
    position: absolute; 
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.fv__header .v__title {
    padding-left: 0;
    color: #fff;
    font-size: clamp(17px, 2.25vw, 36px);
    padding-right: clamp(13px, 1.69vw, 27px);
    padding-top:clamp(22px, 2.88vw, 46px);
	line-height: 1;
}
.post-type-archive-photogallery .fv__header .v__title {
    font-size: clamp(15px, 2.00vw, 32px);	
    letter-spacing: 0.1em;
}	
.fv__header .v__title span {
    font-size: clamp(7px, 0.88vw, 14px);	
    top: clamp(22px, 2.88vw, 46px);
}
.fv__header .v__title::before {
    width: clamp(17px, 2.25vw, 36px);
    height: clamp(17px, 2.25vw, 36px);
    top: 0;
    left: 3px;
}
.fv__header .v__title::after {
    content: none;
}
/*.fv__header-img img {
	aspect-ratio: 4 / 1;
}*/
/***アクセス（wedding,shichigosan,hatsumiyamairi,party）***/
.page-template-page-access-child .fv__header {
	margin-bottom: 0;
}
@media screen and (max-width : 767px) {
	.fv__header{
		height: 200px;
	}
	.fv__header-img img {
		height: 200px;
		object-fit: cover;
	}
	.fv__header .v__title {
		font-size: 20px;
	}
	.fv__header .v__title::before {
		width: 16px; 
		height: 16px;
	}
/*衣裳*/
	.page-dress .fv__header-img img {
		object-position: right;
	}
}
@media screen and (max-width : 670px) {
/*結婚式：神前式・プラン・問合せ*/
	.page-ceremony .fv__header-img img {
        object-position: bottom 0 left -120px;
    }
	.page-id-11 .fv__header-img img {
        object-position: bottom 0 left -120px;
	}
	.page-id-384 .fv__header-img img {
        object-position: bottom 0 left -140px;		
	}
	.page-id-146 .fv__header-img img {
        object-position: bottom 0 right -140px;	
	}
}
/*----------------------------------------------
選ばれる5つの理由
---------------------------------------------- */
.reason a {
    text-decoration: underline;
}
.reason .section__inner {
    max-width: 1244px; 
    padding: 106px 20px 111px;
}
.reason__item + .reason__item {
    margin-top: 65px;
}
.reason__item .media__body {
    margin-left: 40px;
}
.reason__item .media__body {
    margin-left: 40px;
}
.reason__item .reverse .media__body {
    margin-left: 0;
    margin-right: 40px;
}
.reason .media__title {
    font-size: 28px; 
    line-height: 1.5;
    color: var(--beige);
    position: relative;
}
.reason .media__text {
    line-height: 2;
    margin-top: 7px;
}
.reason__list {
    counter-reset: item;
}
.reason__item {
    counter-increment: item;
}
.reason__item .media__title::before {
    content: counter(item) "";
    display: block; 
    font-size: 36px;
    color: #D1D1D1;
    margin-bottom: 6px;
}
@media screen and (max-width : 767px) {
	.reason .section__inner {
		padding: 70px 0;
	}
	.reason .media__title {
		font-size: 24px;
		text-align: center;
	}
	.reason__item .media__title::before {
        font-size: 30px;
        margin-bottom: 0px;
        text-align: center;
    }
	.reason__item .media {
		flex-direction: column;
	}
	.reason__item .media__body {
		margin-left: 0;
		padding-top: 5px;
		padding-left: 15px; 
		padding-right: 15px;
	}
	.reason__item .reverse .media__body {
		margin-right: 0;
	}
}
/*----------------------------------------------
リンクバナー
---------------------------------------------- */
.link__banner-list {
    display: flex;
    flex-wrap: wrap;
}
.link__banner-item {
    position: relative;
    width: 50%;
    height: 440px;
}
.link__banner-item::before {
    content: "";
    position: absolute;
    top: 13px;
    right: 13px;
    bottom: 13px;
    left: 13px;
    border: 1px solid #fff;
    pointer-events: none;
    z-index: 2;
}
.link__banner-title {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-size: clamp(16px, 3vw, 36px);
    text-align: center;
    z-index: 2;
    white-space: nowrap;
}
.link__banner-item a {
    width: 100%;
    height: 100%;
    display: block;
    z-index: 2;
    position: relative;
}
@media screen and (max-width : 767px) {
	.link__banner-item {
		width: 100%;
		height: clamp(200px, calc(200px + 100 * ((100vw - 375px) / 392)), 300px);
	}
	.link__banner-title {
		font-size: 20px;
	}
	.link__banner-item::after {
		opacity: 1;
		content: ""!important;
	}
	.link__banner-item:hover::after {
		opacity: 1;
	}
}
/*----------------------------------------------
YOUTUBE
---------------------------------------------- */
.movie__inner {
    padding: 67px 20px 130px;
}
.movie .section__inner {
    max-width: 1244px;
    padding: 106px 20px 111px;
}
.movie__list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 45px
}
.movie__item {
    width: 100%;
    max-width: 370px;
    text-align: center;
}
.movie__item-title {
    font-size: 22px;
    margin-top: 10px;
    color: #000;
}
.movie__item-img {
  aspect-ratio: 16 / 9;
}
/*1つだけの動画*/
.movie__item-only {
    max-width: 800px;
}
.movie__item-only .movie__item-img {
	width: 100%;
	height: 100%;
}
.movie__item-only .movie__item-title {
    font-size: 24px;
    color: #000;
}
@media screen and (max-width : 767px) {
	.movie__inner {
        padding: 50px 15px 80px;
    }
	.movie__item-title {
		font-size: 18px!important;
	}
}
/*----------------------------------------------
テーブルスタイル
---------------------------------------------- */
.style__table {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.style__table > div {
    display: flex; 
    width: calc(50% - 2.5px);
    gap: 5px;
}
.style__table > div.one-column {
    width: 100%;
}
.style__table dt {
    background: var(--l-beige);
    color: #fff!important;
    width: 171px;
    flex-shrink: 0;
    display: flex;
    align-items: center; 
    justify-content: center;
    font-weight: 700;
    padding: 10px 5px;
}
.style__table dd {
    flex: 1;
    margin: 0;
    padding: 10px 5px 10px 22px;
    padding-left: 22px;
    background: #F8F8F8;
    font-weight: 500;
    line-height: 1.5;
    display: flex;
    align-items: center; 
}
.style__table + .text {
    margin-top: 10px;
}
@media screen and (max-width : 900px) {
    .style__table {
        flex-direction: column;
    }
    .style__table > div {
        width: 100%;
    }
    .style__table dt {
        width: 220px;
    }
}
@media screen and (max-width : 600px) {
    .style__table > div {
        flex-direction: column;
    }
    .style__table dt {
        width: 100%;
    }
    .style__table dd {
        justify-content: center;
    }
}
/*----------------------------------------------
タブ
---------------------------------------------- */
.tab-content { 
    display: none; 
}
.tab-content.active { 
    display: block;
}
.tab-menu {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    gap: 22px;
    border-bottom: 3px solid var(--beige);
    margin-bottom: 31px;
	position: relative; 
	z-index: 2;
}
.tab-menu li {
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 60px;
    background: #EDEDED;
    color: #000;
    font-size: clamp(12px, 1.7vw, 18px);
    transition: .3s;
	text-align: center;
	line-height: 1.5;
}
.tab-menu li.active {
    background: var(--beige);
    color: #fff;
}
.tab-menu li:hover {
    background: var(--beige);
    color: #fff;
    transition: .3s;
}
@media screen and (max-width : 767px) {
	.tab-menu {
		gap: 10px;
	}
	.tab__block {
        margin-top: 50px;
    }
	.tab-menu li {
        font-size: 16px;
        gap: 7px;
    }
	.tab-menu li span {
        font-size: 13px;
        line-height: 1.5;
    }
}
/*=======================================================
衣裳カタログ・ギャラリー
=======================================================*/
.gallery {
	padding-top: 70px;
    padding-bottom: 94px;
}
.gallery:first-of-type {
	padding-top: 0;
}
.gallery:nth-of-type(odd) {
    background: var(--cream);
    padding-top: 70px;
}
.gallery .section__title {
    margin-bottom: 23px;
    color: #000;
}
.gallery .text {
    font-size: 18px;
    text-align: center;
}
.gallery .text + .buttons {
    margin-top: 34px;
}
.gallery .buttons {
    margin-bottom: 53px;
    margin-top: 57px;
	gap: 57px;
}
.gallery .button {
    max-width: 370px;
    height: 70px;  
    font-size: 18px;
    color: #000;  
}
.gallery .button a {
	display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    flex-wrap: wrap;
    align-content: center;
}
/*マイナビウエディングボタン*/
.gallery .buttons > div:first-of-type .button::before {
	content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    background: url(../images/common/icon-link.svg) center / cover no-repeat;
    margin-right: 7px;
}
.gallery .buttons > div:first-of-type .button:hover {
	transform: none;
}
.gallery .buttons .icon-link {
	margin-right: 10px;
    margin-left: -10px;
}
.gellery__wrapper {
    max-width: 1240px; 
    width: 100%;
    margin: auto;
    padding-left: 20px; 
    padding-right: 20px;
}
.gallery__list {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
}
.gallery__item {
    width: 100%;
    max-width: 235px;
}
.gallery__item img {
    width: 100%;
}
.gallery__list:has(.gallery__item--empty) {
	display: block;
}
.gallery__item--empty {
	width: 100%!important;
	max-width: 100%!important;
}
/*フォトギャラリー*/
.post-type-archive-photogallery .gallery__item {
    max-width: 293px;
	aspect-ratio: 1 / 1;
}
.post-type-archive-photogallery .gallery__item img {
    object-fit: cover;
    height: 100%;
}
.post-type-archive-photogallery .gallery .button {
    max-width: 301px;
}
/*fancybox*/
.fancybox__toolbar__column.is-left,
.fancybox__toolbar__column .f-button:not(:last-of-type) {
    display: none!important;
}
.fancybox__backdrop,
.f-button {
    background: rgba(0,0,0,.8)!important;
}
.fancybox__caption {
    padding: 20px 0 35px 0!important;
}
/*ボタン*/
.fancybox__caption .btn__wrapper {
	display: flex; 
	align-items: center; 
	justify-content: center;
	gap: 15px;
}
.fancybox__caption button {
    padding: 10px;
    width: 230px;
    margin-top: 20px;
	position: relative;
}
.fancybox__caption button::before {
    content: "";
    display: block;
    position: absolute;
    left: 25px;
    top: 16px;
}
.fancybox__caption .btn--mail {
    background: var(--red);
    color: #fff!important;
    font-weight: 700;
    border: 1px solid var(--red);
}
.fancybox__caption .btn--mail::before{
    width: 16px;
    height: 12px;
    background-color: #fff;
    -webkit-mask: url(../images/common/icon-mail.svg) no-repeat center / contain;
    mask: url(../images/common/icon-mail.svg) no-repeat center / contain;
    transition: background-color 0.3s ease;
}
.fancybox__caption .btn--mail:hover {
    background: #fff;
    color: var(--red)!important;
}
.fancybox__caption .btn--mail:hover::before {
    background-color: var(--red);
}
.fancybox__caption .btn--dress {
    background: var(--beige);
    color: #fff!important;
    border: 1px solid var(--beige);
}
.fancybox__caption .btn--dress:hover {
    background: #fff;
    color: var(--beige)!important;
}
.fancybox__caption .btn--dress::before {
    width: 17px;
    height: 17px;
    transition: background-color 0.3s ease;
    background: url(../images/common/icon-dress.svg) no-repeat center / contain;
    top: 13px;
}
.fancybox__caption .btn--dress:hover::before {
    background: var(--beige);
    -webkit-mask: url(../images/common/icon-dress.svg) no-repeat center / contain;
    mask: url(../images/common/icon-dress.svg) no-repeat center / contain;
}
/*フォトギャラリーのお問合せ外部リンクマーク外す*/
.post-type-archive-photogallery .link__other-list .link__other-item {
	width: 301px;
}
.post-type-archive-photogallery .link__other-list .link__other-item:nth-of-type(2) .external_link::before {
	content: none;
}
.post-type-archive-photogallery #wedding .link__other-list .link__other-item {
	position: relative;
}
.post-type-archive-photogallery #wedding .link__other-list .link__other-item:nth-of-type(1)::after {
	content: "（マイナビウエディング）";
	position: absolute;
	bottom: 10px;
	left: 65px;
	color: #B4B4B4;
	font-size: 12px;
}
@media screen and (max-width : 767px) {
	.fancybox__caption .btn__wrapper {
		padding-left: 10px; 
		padding-right: 10px;
	}
	.fancybox__caption button {
		font-size: 14px;
		padding-left: 30px;
	}
	.fancybox__caption button::before {
		top: 14px; 
		left: 10px;
	}
	.gallery {
		padding-top: 0;
        padding-bottom: 40px;
		padding-right: 15px; 
		padding-left: 15px;
    }
	.gallery__list {		
    	grid-template-columns: repeat(3, minmax(0, 1fr));
    }
	.gellery__wrapper {
		padding-left: 0;
		padding-right: 0;
	}
	.gallery .text {
		font-size: 16px;
	}
	.gallery .buttons {
		gap: 20px;
		margin-top: 45px;
	}
  .tab-menu {
        display: flex;
        overflow-x: auto;
        gap: 10px;
        border-bottom: 3px solid var(--beige);
        scrollbar-width: none; /* Firefox */
    }
  .tab-menu::-webkit-scrollbar {
        display: none; /* Chrome, Safari */
    }
  .tab-menu li {
        flex: 0 0 auto;
        padding: 8px 16px;
        white-space: nowrap;
        font-size: 14px;
    }
	.scroll-text {
		font-size: 14px; 
		text-align: right;
		margin-top: -25px; 
		margin-bottom: 20px;
	}
	#wedding.gallery .tab-menu li {
		width: 33%;
	}
}
@media screen and (max-width : 425px) {
	.gallery__list {		
    	grid-template-columns: repeat(2, minmax(0, 1fr));
    }
	.section__title {
		font-size: 23px;
	}
}
@media screen and (max-width : 345px) {
	.section__title {
		font-size: 21px;
	}
}
/*=======================================================
プラン
=======================================================*/
/*詳しくはこちらボタン*/
.button.js-accordion {
    margin: auto;
}
.button.js-accordion.active::before {
    transform: translateY(-2%) rotate(180deg);
}
/*中身*/
.js-accordion-detail {
    display: none;
}
.plan__detail {
    margin-top: 87px;
}
.plan__detail .detail__title {
    font-size: 26px;
    font-weight: 500;
    border-bottom: 2px solid var(--red);
    margin-bottom: 20px;
    padding-bottom: 10px;
	line-height: 1.6;
}
.plan__detail * + .detail__title {
    margin-top: 53px;
}
.plan__detail .style__list {
    margin-bottom: 17px;
}
.plan__detail .style__list div + div {
    margin-top: 25px;
}
.plan__detail .style__list dt {
    color: var(--beige);
    font-size: 22px;
    font-weight: 600;
    margin-bottom: 10px;
}
.plan__detail .style__list dd {
    line-height: 1.6;
}
.plan__detail .list {
	text-indent: -1em;
    padding-left: 1em;
}
.plan__detail .list::before {
	content: "※";
}
/*オプションプラン*/
.option__plan {
    display: flex;
    gap: 24px;
	position: relative;
}
.option__plan-img {
    max-width: 341px;
    width: 100%;
}
.option__plan-img img {
	object-fit: cover;
	height: 100%;
}
.option__plan-body {
    flex: 1;
    background: #F8F8F8;
	padding: 20px 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.option__plan-title {
    font-size: 22px; 
    font-weight: 500;
    color: #000;
    border-bottom: 2px solid var(--beige);
    padding-bottom: 13px;
    margin-bottom: 12px;
}
.option__plan-title span {
    color: var(--beige);
    font-size: 15px;
    margin-left: 1em;
}
.option__plan-price {
    font-size: 26px;
    font-weight: 500;
    margin-bottom: 8px;
}
.option__plan-price span {
    font-size: 20px;
    font-weight: 600;
}
.option__plan .more__button {
    text-align: left; 
    margin-top: 30px;
}
/*左に画像右にテーブル*/
.detail__media {
    display: flex; 
    align-items: center;
    gap: 60px;
    align-items: flex-start;
    margin-top: 34px;
}
.detail__media > * {
    width: 50%;
}
/*地図*/
.plan__map {
    margin-top: 153px;
}
@media screen and (max-width : 1000px) {
    .plan__outline {
        flex-direction: column;
    }
    .plan__img {
        max-width: 100%;
    }
}
@media screen and (max-width : 900px) {
    .detail__media {
        flex-direction: column;
    }
    .detail__media > * {
        width: 100%;
    }
}
@media screen and (max-width : 767px) {
	.plan__detail .detail__title {
		font-size: 22px; 
		text-align: center;
	}
	.option__plan {
		flex-direction: column;
	}
	.option__plan-body {
		padding: 25px;
	}
	.option__plan-img {
		max-width: 100%;
	}
	.plan__detail .style__list dt {
        font-size: 20px;
	}
	.option__plan-title {
		font-size: 20px;
		line-height: 1.5;
	}
	.option__plan-title span {
		margin-left: 0;
		display: block;
		margin-top: 10px;
	}
	.option__plan-price {
		font-size: 24px;
	}
	.option__plan-price span {
		font-size: 18px;
	}
	.option__plan .more__button {
        margin-top: 20px;
        justify-content: flex-end;
    }
}
/*----------------------------------------------
ページ内リンク用ボタン群
---------------------------------------------- */
.page__link-inner {
    max-width: 1240px; 
    margin: auto auto 100px;
    padding: 0 20px;
}
.page__link {
    display: flex; 
    justify-content: center;
    margin: auto;
	flex-wrap: wrap;
}
.page__link-item {
    position: relative;
}
.page__link-title {
    text-align: center;
}
.page__link-title span {
    display: block;
}
/*シンプル*/
.page__link-simple-wrapper .page__link {
    gap: 20px;
}
/*宴会場*/
.page__link-text-title {
    font-size: 26px;
    border-bottom: 2px solid var(--red);
    padding-bottom: 4px; 
    margin-bottom: 33px;
}
.page__link-text-wrapper .page__link {
    gap: 65px;
}
.page__link-text-wrapper .page__link-item {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.page__link-text-wrapper .page__link-title {
    color: var(--beige);
    font-size: 24px;
    text-align: center;
    display: inline-block;
    border-bottom: 1px solid var(--beige);
    padding-bottom: 1px;	
}
.page__link-text-wrapper .page__link-item > span {
    font-size: 18px; 
    color: #000;
    margin-top: 15px
}
/*プラン*/
.page__link-banner-wrapper .page__link {
    gap: clamp(26px, 3.33vw, 40px);
    padding: 0 clamp(13px, 1.67vw, 20px) clamp(49px, 6.42vw, 77px);
}
.page__link-banner-wrapper .page__link-item {
    max-width: clamp(173px, 22.58vw, 271px);
    height: clamp(116px, 15.08vw, 181px);
    width: 100%;
}
.page__link-banner-wrapper .page__link-title {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-size: clamp(17px, 2.17vw, 26px);
    font-weight: 500;
    width: 100%;
}
.page__link-banner-wrapper .page__link-title span {
    font-size: clamp(14px, 1.83vw, 22px);
    margin-top: clamp(5px, 0.67vw, 8px);
}
.page__link-banner-wrapper .page__link-item:last-of-type .page__link-title {
    letter-spacing: -0.15em;
}
.page__link-banner-wrapper .page__link-item:last-of-type .page__link-title span {
    letter-spacing: 0;
}
.page__link-banner-wrapper .page__link-item::after {
    content: "";
    display: block;
    width: 17px;
    height: 9px;
    background: url(../images/common/arrow-below.svg) center / cover no-repeat;
    position: absolute; 
    left: 0;
    right: 0;
    bottom: clamp(10px, 1.9vw, 16px);
    margin: auto;
}
.page__link-banner-wrapper .page__link-item img {
    height: clamp(116px, 15.08vw, 181px);
    object-fit: cover;
}
@media screen and (max-width : 767px) {
	.page__link-text-title {
		font-size: 23px;
	}
	.page__link-text-wrapper .page__link {
        gap: 30px;
    }
	.page__link-text-wrapper .page__link-title {
		font-size: 22px;
	}
	.page__link-text-wrapper .page__link-item > span {
		font-size: 16px;
	}
}
@media screen and (max-width : 393px) {
	.page__link-banner-wrapper .page__link-item {
		max-width: 160px;
	}
}
/*----------------------------------------------
リードコピー
---------------------------------------------- */
.lead__inner {
    margin-bottom: 67px;
    margin-top: 94px;
    padding: 0 20px;
}
.lead__title {
    font-size: 32px;
    letter-spacing: 0;
    margin-bottom: 22px;
    text-align: center;
    line-height: 1.4;
    color: var(--beige);
}
.lead__text {
    font-size: 18px;
    color: #000;
    line-height: 2;
    text-align: center;
}
@media screen and (max-width : 767px) {
	.lead__inner {
        margin-bottom: 67px;
        margin-top: 50px;
        padding: 0 15px;
    }
	.lead__title {
		font-size: 26px;
	}
	.lead__text {
		font-size: 16px;
	}
}
/*----------------------------------------------
宴会場
---------------------------------------------- */
.banquet__block .section__inner {
    margin-bottom: 149px;
}
.banquet__item + .banquet__item {
    margin-top: 119px;
}
.banquet__body {
    padding: 0 20px;
    text-align: center;
    margin-top: 55px;
}
.banquet__title {
    margin-bottom: 15px;
}
.banquet__title + .text {
    font-size: 18px;
}
.banquet__subtitle {
    margin: 30px 0 16px;
    font-size: 32px;
    font-weight: 500;
    color: var(--beige);
}
.banquet__text {
    line-height: 2;
    color: #000;
}
@media screen and (max-width : 767px) {
	.banquet__block .section__inner {
        margin-bottom: 70px;
    }
	.banquet__item + .banquet__item {
        margin-top: 70px;
    }
	.banquet__title {
        margin-bottom: 5px;
    }
	.banquet__title + .text {
        font-size: 16px;
    }
	.banquet__subtitle {
        font-size: 26px;
        line-height: 1.5;
    }
}
/*----------------------------------------------
シンプルなスライダー
---------------------------------------------- */
.simple__slider {
    width: 100%;
    margin: 0 auto;
}
.simple__slider .slick-slide {
    text-align: center;
}
.simple__slider img {
    width: 800px;
    max-width: 100%;
    margin: 0 auto;
    height: auto;
}
.simple__slider .slick-slide {
    margin: 0 6px;
}
/*dots*/
.simple__slider .slick-dots,
.report__slider .slick-dots {
    bottom: -29px;
}
.simple__slider .slick-dots li,
.report__slider .slick-dots li {
    width: 12px;
    height: 12px;
    margin: 0 4px;
}
.simple__slider .slick-dots li button,
.report__slider .slick-dots li button {
    width: 100%;
    height: 100%;
    padding: 0;
}
.simple__slider .slick-dots li button:before,
.report__slider .slick-dots li button:before {
    width: 12px;
    height: 12px;
    opacity: 1;
    background: #ccc;
    font-size: 0;
    border-radius: 50%;
}
.simple__slider .slick-dots li:hover button:before,
.simple__slider .slick-dots li.slick-active button:before,
.report__slider .slick-dots li:hover button:before,
.report__slider .slick-dots li.slick-active button:before {
    background: var(--beige);
}
/*----------------------------------------------
サムネイル付きスライダー
---------------------------------------------- */
.thumb__slider-wrapper .thumb__slider-nav {
    display: flex; 
    align-items: center; 
    justify-content: center;
    margin-top: 13px;
	flex-wrap: wrap;
}
.thumb__slider-wrapper .thumb__slider-nav img {
    cursor: pointer;
    object-fit: cover;
}
/*----------------------------------------------
強みや流れなどタイトル縦書きメディア
---------------------------------------------- */
.flow-block {
    margin-bottom: 84px;
}
.flow-block .flow__item + .flow__item {
    margin-top: 130px;
}
.flow-block .flow__item .media {
    align-items: flex-start;
}
.flow-block .media__img {
    max-width: 800px;
    position: relative;
}
.flow-block .media__body {
    text-align: center;
    padding: 0 20px;
}
.flow-block .media__title {
    font-size: 32px; 
    color: var(--beige);
    writing-mode: vertical-rl;
    display: flex; 
    align-items: center;
    letter-spacing: 0.25em;
    position: relative;
    line-height: 1.6;
    text-align: left;
}
.flow-block .media__title.two-lines::before {
    margin-left: 50px;
}
.flow-block .media__title::before {
    content: "一、";
    letter-spacing: 3px;
    margin-bottom: -12px;
}
.flow-block .flow__item:nth-of-type(2) .media__title::before {
    content: "二、";
}
.flow-block .flow__item:nth-of-type(3) .media__title::before {
    content: "三、";
}
.flow-block .flow__item:nth-of-type(4) .media__title::before {
    content: "四、";
}
.flow-block .media__text {
    font-size: 18px; 
    line-height: 2;
    color: #000;
    margin-top: 30px;
}
@media screen and (max-width : 767px) {
	.flow-block {
        margin-bottom: 70px;
    }
	.flow-block .section__inner {
		padding-left: 0;
		padding-right: 0;
	}
	.flow-block .media__text {
		font-size: 16px;
		margin-bottom: 30px;
		padding-left: 15px; 
		padding-right: 15px;
	}
	.flow-block .media__title {
		font-size: 26px;
	}
	.flow-block .flow__item + .flow__item {
        margin-top: 70px;
    }
	.flow-block .media__body {
		margin: auto;
		padding-left: 0;
		padding-right: 0;
	}
	.flow-block .media__title.two-lines::before {
		margin-left: 40px;
	}
}
/*----------------------------------------------
結婚式・宴会会場プラン
---------------------------------------------- */
.plan__block .section__inner {
    max-width: 1240px; 
    margin: auto;
    padding: 97px 20px;
}
.plan__item {
    padding: 63px 55px 52px;
    background: #fff;
    scroll-margin-top: 84px!important;
}
.plan__item + .plan__item {
    margin-top: 48px;
}
.plan__title {
    text-align: center;
    color: var(--beige);
    font-size: 32px;
    font-weight: 500;
    margin-bottom: 36px;
}
.plan__outline {
    display: flex; 
    gap: 39px;
    margin-bottom: 51px;
}
.plan__body {
    width: 100%;
}
.price__number {
    font-size: 30px;
    font-weight: 500;
}
.plan__body .text {
    line-height: 1.65;
}
.plan__thumb-wrapper {
    margin-top: 14px; 
    background: #F8F8F8;
    padding: 9px 14px 17px;
}
.plan__thumb-title {
    font-size: 22px; 
    font-weight: 500;
    text-align: center;
    margin-bottom: 8px;
}
.plan__thumb {
    display: flex;
    justify-content: center;
    gap: 21px;
}
.plan__thumb-item {
    width: 175px;
}
.plan__thumb-item figcaption {
    text-align: center;
    font-size: 18px;
    margin-top: 7px;
}
.plan__img {
    max-width: 434px;
    width: 100%;
	margin: auto;
}
@media screen and (max-width : 767px) {
	.plan__block .section__inner {
		padding: 70px 20px;
	}
	.plan__item {
        padding: 50px 20px;
        background: #fff;
        scroll-margin-top: 84px !important;
    }
	.plan__title {
        font-size: 24px;
        margin-bottom: 15px;
        line-height: 1.5;
    }
	.price__number {
		font-size: 24px;
	}
	.plan__price {
        font-size: 16px;
	}
	.plan__thumb-title {
        font-size: 18px;
        margin-bottom: 5px;
    }
	.plan__thumb {
        gap: 15px;
    }
	.plan__thumb-item {
        width: 50%;
    }
	.plan__thumb-item figcaption {
        font-size: 14px;
		line-height: 1.2;
    }
	.plan__img {
        max-width: 100%;
        width: 100%;
    }
}
/*----------------------------------------------
七五三の詳細・料理の詳細
---------------------------------------------- */
.course__detail {	
    background: #fff; 
    border-radius: 20px;
    padding: 41px 47px 64px;
}
.price__wrapper {
    display: flex;
    margin-top: 15px;
    gap: 29px;
}
.price__wrapper > * {
	flex: 1;
}
.price__inner {
    max-width: 400px; 
    width: 100%;
    flex-shrink: 0;
}
.price__img-wrapper {
    display: flex;
    gap: 27px;
}
.price__img {
    text-align: center; 
    font-weight: 500;
}
.price__img-title {
    margin-top: 5px;
}
.price__list > div {
    border-top: 1px solid #ccc;
    padding: 8px 0;
    display: flex;
    justify-content: space-between;
}
.price__list > div:last-of-type {
    border-bottom: 1px solid #ccc;
}
.price__list > div dt {
    font-weight: 400;
	display: flex; 
	align-items: center;
	gap: 5px 15px;
}
.price__list > div dt span {
	font-size: 14px; 
	font-weight: 700;
	display: block; 
	background: var(--red);
	color: #fff;
	padding: 4px 8px 5px;
}
.price__list > div dd span {
    font-size: 12px;
    display: block;
    margin-top: 5px;
}
.price__list + p {
    margin-top: 10px;
}
.price__list + p + a {
    margin-top: 15px;
    display: block;
}
.price__list + .option__title {
	margin-top: 30px;
}
.option__title {
	color: var(--beige);
	margin-bottom: 10px; 
	font-weight: 500;
}
@media screen and (max-width : 767px) {
.price__list > div dt {
	flex-wrap: wrap;
}
	.price__list > div dt span {
		padding: 2px 6px 3px;
	}
}
/*----------------------------------------------
会社概要
---------------------------------------------- */
.page-company .section__inner {
	max-width: 1240px;
	padding: 0 20px;
	margin-top: 116px;
	margin-bottom: 165px;
}
.page-company .company__detail {
	width: 100%;
}
.page-company .company__detail tr {
	display: flex;
}
.page-company .company__detail tr > * {
	padding: 15px 0 14px;
	font-weight: 500;
	line-height: 1.6;
	color: #000;
}
.page-company .company__detail th {
	text-align: center;
	border-top: 1px solid var(--red);
	width: 250px;
}
.page-company .company__detail tr:last-of-type th {
	border-bottom: 1px solid var(--red);
}
.page-company .company__detail td {
	border-top: 1px solid #D9D9D9;
	width: 100%;
	padding-left: 27px; 
	padding-right: 27px;
}
.page-company .company__detail tr:last-of-type td {
	border-bottom: 1px solid #D9D9D9;
}
@media screen and (max-width : 767px) {
	.page-company .section__inner {
		margin-top: 70px;
		margin-bottom: 70px;
	}
}
/*----------------------------------------------
プライバシーポリシー
---------------------------------------------- */
.page-privacy-policy .fv__header .v__title::before {
    left: clamp(23px, 3.00vw, 48px);
}
.page-privacy-policy .fv__header .v__title {
	line-height: 1.3;
}
.page-privacy-policy .section__inner {
	max-width: 1240px;
	padding: 0 20px;
	margin-top: 77px;
	margin-bottom: 100px;
}
.page-privacy-policy .privacy__title {
	font-size: 26px;
    font-weight: 500;
    line-height: 1.4;
    color: #000;
	border-bottom: 2px solid var(--red);
	padding-bottom: 4px;
    margin-bottom: 21px;
}
.page-privacy-policy .privacy__subtitle {
	font-weight: 600;
	line-height: 1.5; 
	margin-bottom: 3px;
}
.page-privacy-policy .text {
	margin-bottom: 25px;
}
.page-privacy-policy .privacy__detail + .privacy__title {
	margin-top: 55px;
}
@media screen and (max-width : 767px) {
	.page-privacy-policy .section__inner {
		margin-top: 70px;
		margin-bottom: 70px;
	}
	.page-privacy-policy .privacy__title {
        font-size: 20px;
	}
}
/*----------------------------------------------
よくある質問
---------------------------------------------- */
.post-type-archive-faq .buttons {
	max-width: 1060px;
	margin: 71px auto 120px;
	padding: 0 20px;
	gap: 24px; 
	display: flex;
	flex-wrap: wrap;
}
.post-type-archive-faq .button {
	width: 309px;
	height: 60px;
	font-size: 18px;
}
.post-type-archive-faq .section:not(.fv__header) {
	margin-bottom: 170px;
}
.post-type-archive-faq .section__inner {
	max-width: 1240px; 
	margin: auto;
	padding: 0 20px;
}
.faq__heading {
	font-size: 26px;
    font-weight: 500;
    line-height: 1.4;
    color: #000;
	border-bottom: 2px solid var(--red);
	padding-bottom: 4px;
    margin-bottom: 20px;
	display: flex; 
	align-items: center;
}
.faq__heading::before {
	content: "";
    display: block;
    width: 36px;
    height: 36px;
    background: url(../images/common/mini-mark.svg) center / cover no-repeat;
	margin-right: 13px;
}
.faq__heading::after {
	content: "よくある質問";
	padding-left: 1em;
}
.faq__item {
	padding: 14px 0 14px 47px;
	border-bottom: 1px solid #D9D9D9;
}
.faq__item > * {
	line-height: 1.5;
}
.faq__question {
	cursor: pointer;
	position: relative;
	font-size: 18px;
	font-weight: 500;
}
.faq__question::before {
	content: "Q.";
	color: var(--beige);
	margin-right: 10px;
}
.faq__answer {
	padding: 23px 0;
}
.faq__answer a:hover {
	color: var(--beige);
}
.faq__answer a::before {
    content: "";
    display: inline-block;
    background: url(../images/common/icon-accordion.svg) center / cover no-repeat;
    width: 9px;
    height: 5px;
    z-index: 2;
    margin-right: 6px;
	transform: rotate(270deg);
	margin-bottom: 3px;
}
.faq__none {
	padding: 14px 0 14px 47px;
}
@media screen and (max-width : 767px) {
	.post-type-archive-faq .section:not(.fv__header) {
        margin-bottom: 70px;
    }
	.faq__heading {
		font-size: 24px;
		justify-content: center;
	}
	.faq__heading::before {
        width: 26px;
        height: 26px;
		margin-right: 7px;
	}
	.faq__item,
	.faq__none {
		padding: 10px 0;
	}
	.faq__heading::after {
		content: none;
	}
}
/*=======================================================
お知らせ
=======================================================*/
.news .section__inner {
	max-width: 1240px; 
	padding: 0 20px;
	margin-bottom: 145px;
}
.news .news__list {
	max-width: 100%;
}
.news .no-post {
	padding: 20px 0 18px;
    border-bottom: 1px solid #ccc;
}
.news .btn-more {
	margin: 50px auto auto;
	text-align: center;
}
.news .link__other-item {
    border: 1px solid var(--beige);
    background: #fff;
    position: relative;
	max-width: 160px;
    height: 40px;
}
.news .link__other-item::before {
    content: "";
    display: inline-block;
    background: url(../images/common/icon-accordion.svg) center / cover no-repeat;
    width: 13px;
    height: 7px;
    margin-right: 12px;
    margin-bottom: 2px;
}
.news__item.hidden {
	display: none;
}
.news__item.fade-in {
    display: block;
    opacity: 0;
    transform: translateY(-10px);
    animation: fadeSlideDown 0.5s ease forwards;
}
@keyframes fadeSlideDown {
    0% {
        opacity: 0;
        transform: translateY(-10px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
/*詳細ページ*/
.news__single .section__inner {
	margin-top: 81px;
}
.news__single .news__title {
	font-size: 24px;
	color: #000;
	border-bottom: 2px solid var(--red);
	margin-bottom: 22px;
}
.news__single .news__day {
	font-size: 18px;
}
.news__single .news__cat {
	font-size: 16px;
	height: 30px;
}
.news__single .news__meta {
	margin-bottom: 7px;
}
.news__detail p,
.news__detail figure {
	margin-bottom: 30px;
}
/*中見出し */
.news__single .ttl,
.wp-block-heading {
	font-size: 22px;
    margin-bottom: 10px;
	line-height: 1.6;
	padding-bottom: 8px;
    border-bottom: 1px dotted #b0a89f;
}
/*小見出し*/
.news__single .sub_ttl {
	font-size: 20px;
	margin-bottom: 10px;
	line-height: 1.6;
}
/*リスト*/
.wp-block-list {
	display: block;
    list-style-type: disc;
    margin-block-start: 1em;
    margin-block-end: 1em;
    padding-inline-start: 40px;
    unicode-bidi: isolate;
}
.wp-block-list li + li {
	margin-top: 5px;
}
/*小さい字*/
.news__single .fs-s {
	font-size: 14px;
	line-height: 1.6;
}
/*リンク*/
.news__single a:not(.news__cat):not(.button) {
	text-decoration: underline;
}
/*下余白*/
.news__single .mb {
	margin-bottom: 60px;
}
/*上余白*/
.news__single .mt {
	margin-top: 60px;
}
.backto__list {
	margin: 68px auto auto;
	display: flex; 
	justify-content: center;
}
/*画像真ん中に*/
.news__single img {
	display: block; 
	margin: auto;
	max-width: 770px;
}
@media screen and (max-width : 767px) {
	.news .section__inner {
		margin-bottom: 70px;
	}
	.news__single .news__title {
		font-size: 20px;
	}
	.news__single .ttl {
        font-size: 20px;
	}
	.news__single .sub_ttl {
        font-size: 18px; 
	}
}
/***slick***/
/* 初期状態でも1枚目だけ表示、slick前に縦並び防止 */
.fv__slider:not(.slick-initialized) > *:not(:first-child),
.simple__slider:not(.slick-initialized) > *:not(:first-child),
.souvenir__slider:not(.slick-initialized) > *:not(:first-child),
.thumb__slider:not(.slick-initialized) > *:not(:first-child),
.report__slider:not(.slick-initialized) > *:not(:first-child) {
  display: none;
}

/* slick初期化後のフェードイン */
.fv__slider,
.simple__slider,
.souvenir__slider,
.thumb__slider,
.report__slider {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.3s ease;
}

.slick-initialized {
  opacity: 1;
  visibility: visible;
}
/*会場スクロール*/
.toscroll {
	display: none;
}
@media screen and (max-width : 860px) {
	.toscroll {
		display: block;
		text-align: center; 
		font-size: 12px;
		margin-top: -10px;
	}
}