@charset "UTF-8";

html { scroll-behavior: smooth;}
body {
	background-image: url(../img/background.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	background-attachment: fixed;
	height: 100vh;
/*  background-image: linear-gradient(0deg, rgb(255 236 194), rgb(229 254 255));*/
}
.MainContentBlock {
/*	background-color: #f5f5f5;*/
}
article.page-base {
	max-width: 480px !important;
	margin: auto;
  box-shadow: 0px 0px 20px 3px rgba(0, 0, 0, 0.2);
  right: -20%;
}
.mainvisual {
	height: 80vh;
  padding-top: 0;
  position: relative;
}
.mainvisual_title{
	position: absolute;
  top: 280px;
  padding: 0 5%;
}
/*
.mainvisual:after {
	display: none;
}*/
@media only screen and (max-width: 48em) {
.mainvisual {
  right: 0;
  box-shadow: none;
}
article.page-base {
  right: 0;
  box-shadow: none;
}
}


.header-neo-inner h1 {
	text-align: left;
}
.header-neo-inner h2 {
	font-size: 18px;
  padding: 0 5%;
}
.header-neo-inner p {
	color: #49bbbc;
}
div.Page-header-neo h1.header-neo-item1::after {
	display: none;
}
.header-neo-item1 img {
	width: 50%;
}
.contents_text h2 span.text_3{
  font-size: 23px;
  font-weight: bold;
  padding: 15px 0;
}
.contents_text h2 span.text_3.border{
  border-top: #fff solid 2px;
  border-bottom: #fff solid 2px;
}
.contents_text h2 span.text_5{
  font-size: 35px;
  font-weight: bold;
}
.contents_text h2 span.text-bold{
  font-size: 20px;
  font-weight: bold;
}


.header_maintxt_sub {
	width: 70%;
	position: absolute;
	bottom: 30px;
	left: 0;
}
@media only screen and (max-width: 30em) {
.header-title_img {
	max-width: 80px; /* 180px */
}
.contents_text h2 span{
  font-size: 25px;
}
}

video {
	width: 100%;
}

h2 {
	font-size: 24px;
	font-weight: normal;
	color: #000000;
	font-family: "EB Garamond", serif;
}

.heading_box {
	width: 100%;
	position: relative;
	/*overflow-x: hidden;*/
}
.heading_box img.heading_imgboxA{
	width: 100%;
}
.heading_box img.heading_imgboxB{
	width: 100%;
	/*margin-left: 10%;*/
}
.heading_box img.heading_imgboxC{
	width: 80%;
}
.heading_box img.heading_imgboxD{
	width: 80%;
	margin-left: 20%;
}

/* フェア見出し */
.flex_2A {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	position: absolute;
	top: -30px;
	right: 10px;
	background-color: #f5f5f5;
	padding: 5px;
}
.flex_2A.typel{
	position: absolute;
	top: -30px;
	right: auto;
	left: 10px;
}
.flex_2A div{
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
}
.flex_2A p.number{
	font-size: 50px;
	color: #ba9867;
	line-height: 40px;
	padding-bottom: 10px;
}
.flex_2A p.heading_txtboxC {
	font-size: 24px !important;
}
/*flex_2A 2段 48:48 */
.flex_2A{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.flex_2A div, .flex_2A section{
    width: 48%;
}

/*flex_2B 38:60 */
.flex_2B{
	display: flex;
  align-items: center;  
}
.flex_2B .flex_2B_left{
    width: 38%;
}
.flex_2B .flex_2B_right{
    width: 60%;
}

@media only screen and (max-width: 48em) {
.flex_2A div, .flex_2A section{
	width: 48%;
	margin: 0 0 0 0;
}
.flex_2B .flex_2B_left{
    width: 33%;
}
.flex_2B .flex_2B_right{
    width: 67%;
}
}

.heading_txtboxA {
	position: absolute;
	top: 0;
	right: 30px;
	display: inline;
	background-color: #f5f5f5;
	padding: 5px;
	color: #ba9867;
}
.heading_txtboxB {
	position: absolute;
	bottom: 0;
	left: 30px;
	display: inline;
	background-color: #f5f5f5;
	padding: 5px;
	color: #ba9867;
}
.heading_txtboxD{
	position: absolute;
	top: -30px;
	left: 30px;
	display: inline;
	background-color: #f5f5f5;
	padding: 5px;
}
.heading_txtboxE {
	background-color: #f5f5f5;
	padding-top: 15px;
	padding-bottom: 15px;
	color: #ffffff;
	writing-mode: horizontal-tb;
	background-color: #ba9867;
	width: 100%;
	text-align: center;
	font-size: 24px;
	line-height: 1.2;
}
.heading_txtboxE span{
	font-size: 32px;
}
.heading_txtboxD h2{
	font-size: 24px !important;
}
.txtbox {
	width: 90%;
	margin: auto;
}
.txtstyleA {
	font-size: 13px;
  line-height: 2.5rem;
}




/* コンテンツ一覧 */
.contents_box {
	text-align: center;
  padding: 5% 5% 10% 5%;
}
.contents_box_A {
  padding: 7% 5% 1%;
  border-radius: 10px;
}
.contents_box h2{
	writing-mode: horizontal-tb;
  font-size: 20px;
  color: #fff;
  padding: 5px 0;
}
.flex_3A_fair {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.flex_3A_fair .flex_3A_fair_inner{
	width: 48%;
}
.flex_3A_fair_inner p{
  border: #49bbbc;
  color: #49bbbc;
}
.tag_text{
 border: #49bbbc solid 1.5px;
 background-color: #fff;
 border-radius: 20px;
 font-weight: bold;
 margin: 8px 0 10px 0;
 padding: 1px 0;
}

.contents_title{
  position: absolute;
  top: -85px;
  right: 0;
  left: 0;
  margin: 0 auto;
}
@media only screen and (max-width: 48em) {
.contents_title{
  top: -75px;
}
}


/* アバウト */
.about_box{
	margin: auto;
	position: relative;
}
.about_box h2{
	writing-mode: horizontal-tb;
	text-align: center;
}
.about_box .typeA{
	width: 100%;
	margin: auto;
}
.about_box .typeA img{
	width: 80%;
	display: block;
	margin: auto;
}
.about_box2{
	text-align: center;
	width: 100%;
	margin: auto;
  padding: 15% 0 25% 0;
}
.about_box2 h3{
	font-size: 14px;
	border-bottom: 1px solid #463e3a;
	display: inline-block;
}
.about_box2 h3 span{
	font-size: 18px;
}



/* footer */
.footer_area{
	background-color: #fff;
	margin: auto;
	position: relative;
	text-align: center;
	padding-bottom: 100px;
	padding-top: 20px;
}
.footer_logo_box {
	width: 35%;
	margin: auto;
}
.footer_copy {
	font-size: 12px;
	text-align: center;
	font-weight: normal;
	color: #9c9c9c;
}


/* swiper */
/*
.swiper--wrapper {
   /*wrapperのサイズを調整 */
   /*   
  width: 100%;
  height: 300px;
  margin-bottom: 0;
  padding: 0;
}*/
.swiper {
   overflow: hidden;
   position: relative;
}







.swiper-button-next,.swiper-button-prev {
	top: revert-layer;
}
.swiper-pagination-fraction, .swiper-pagination-custom, .swiper-container-horizontal > .swiper-pagination-bullets {
	bottom: 0;
}
.swiper-pagination-bullet-active {
    background-color: #888;
}
/* 矢印色の置き換え */
.swiper-button-prev,.swiper-container-rtl .swiper-button-next{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%2335B1C5'%2F%3E%3C%2Fsvg%3E");left:10px;right:auto}

.swiper-button-next,.swiper-container-rtl .swiper-button-prev{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%2335B1C5'%2F%3E%3C%2Fsvg%3E");right:10px;left:auto}



/* ========== marginBottom ========== */
.mb5{ margin-bottom:5px !important; }
.mb10{ margin-bottom:10px !important; }
.mb20{ margin-bottom:20px !important; }
.mb30{ margin-bottom:30px !important; }
.mb50{ margin-bottom:50px !important; }


/* ========== padding ========== */
.pdt_05p{ padding-top: 5% !important; }
.pdb_05p{ padding-bottom: 5% !important; }
.pdb_10p{ padding-bottom: 10% !important; }
.pdtb10p{ 
	padding-top: 10% !important;
	padding-bottom: 10% !important;
}


/* =========== backgroundcolor =========== */
.bg_color_gray { background-color: #f5f5f5 !important; }
.bg_color_white { background-color: #ffffff !important; }
.bg_color_blue { background-color: #f8fdfd !important; }
.bg_color_turquoise { background-color: #49bbbc !important; }
.bg_color_beige { background-color: #fffcf6 !important; }
.bg_color_green { background-color: #e4f1ec !important; }


/* =========== textColor =========== */
.text_white{  color: #fff !important;}
.text_gold{  color: #d2b573 !important;}
.text_orange{  color: #ffad18 !important;}
.text_brown{  color: #3e2e22 !important;}



/* =========== btn =========== */
*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}
.btn,
a.btn,
button.btn {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3;
  /*position: relative;*/
  display: block;
  padding: 20px 0;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #49bbbc;
  /*border-radius: 0.5rem;*/
  width: 100%;
  margin: auto;
}
a.btn-border {
/*  border: 2px solid #35B1C5;
  border-radius: 0;
  color: #fff;
  background: #35B1C5;
  border-radius: 50% / 100% 100% 0 0;*/
  display: inline-block;
  width: 100%;
  /*border-radius: 50% / 100% 100% 0 0;*/
  background: #49bbbc;
  opacity: 0.8;
  color: #fff;
}
.btn_flex {
	position: fixed !important;
	bottom: 0;
	z-index: 5000;
	width: 100%;
	max-width: 480px;
}


/* 電話番号 */
.txt_01 {
	text-align: center;
	font-size: 14px;
	font-weight: bold;
}
.txt_01 span{
	font-size: 18px;
	/*font-family: "游明朝", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "ヒラギノ明朝 Pro W3", "HiraMinProN-W3", "HG明朝E", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HGS明朝E", "ヒラギノ明朝 Pro W6", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;*/
}
.txt_02 {
	text-align: center;
	font-size: 14px;
	font-weight: bold;
	text-decoration: underline;
}

/*アニメーション要素のスタイル*/
/*.animation{
	opacity : 0;
	visibility: hidden;
	transition: 1s;
	transform: translateY(30px);
}
/*アニメーション要素までスクロールした時のスタイル*/
/*.active-in{
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}*/







/* ----- 背景用の動画ファイル ----- */
#bg-video{
 position: fixed;
 right: 0;
 bottom: 0;
 min-width: 100%;
 min-height: 100%;
 width: auto;
 height: auto;
 z-index: -100;
/* background: url('img/background.jpg') no-repeat;*/
 background-size: cover;
}
/* ----- 背景の上に表示させたいコンテンツ ----- */
.header-title{
 position: relative; /*必ず必要*/
 z-index: 2; /*必ず必要*/
 display: flex;
 width: 50%;
 justify-content: center;
 align-items: center;
 text-align:center;
 margin: auto;
}




/*============= Btn =============*/
.btn_area{
text-align: center;
margin: auto;
}

.Btn_01,
a.Btn_01,
button.Btn_01 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #000;
  border-radius: 0.5rem;
  background-color: #fff;
  border: solid 2px #000;
}
.Btn_01 span{
  font-size: 1.3rem;
}
a.btn--blue.btn--cubic {
  border-bottom: 5px solid #000;
}

a.btn--blue.btn--cubic:hover {
  margin-top: 3px;
  border-bottom: 2px solid #000;
}

a.btn--radius {
  border-radius: 100vh;
}

.fa-position-right {
  position: absolute;
  top: calc(50% - .5em);
  right: 1rem;
}

/*============= Btn =============*/






/* =========== GALLERY =========== */

.img_box04 {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
}
.img_box04_inner {
  margin-bottom: 2%;
	position: relative;
	overflow:hidden;
	width: calc(33% - 0.3vw);
  box-sizing: border-box;
}
.img_box04_inner img{
	display: block;
	transition:1s all;
	max-width: 100%;
	height: auto;
}
.img_box04_inner img:hover{
  transform:scale(1.2,1.2);
  transition:1s all;
}

@media only screen and (max-width: 48em) {
.img_box04 {
}
.img_box04_inner {
	margin-bottom: 1%;
	width: calc(33.5% - 0.8vw);
}
}

.modal-2__wrap input {
    display: none;
}
.modal-1__open-label,
.modal-1__close-label,
.modal-2__open-label,
.modal-2__close-label,
.modal-3__open-label,
.modal-3__close-label,
.modal-4__open-label,
.modal-4__close-label,
.modal-5__open-label,
.modal-5__close-label,
.modal-6__open-label,
.modal-6__close-label,
.modal-7__open-label,
.modal-7__close-label,
.modal-8__open-label,
.modal-8__close-label,
.modal-9__open-label,
.modal-9__close-label,
.modal-10__open-label,
.modal-10__close-label,
.modal-11__open-label,
.modal-11__close-label,
.modal-12__open-label,
.modal-12__close-label{
    cursor: pointer;
}

.modal-2 {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: none;
}
.modal-2__open-input:checked + label + input + .modal-2 {
    display: block;
    animation: modal-2-animation .6s;
}
.modal-2__content-wrap {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    max-width: 650px;
    background-color: #fefefe;
    z-index: 2;
}
.modal-2__close-label {
    /* background-color: #fff; */
    color: #000;
    /* border: 1px solid #000; */
    /* border-radius: 50%; */
    /* line-height: 33px; */
    /* text-align: center; */
    display: table-cell;
    position: fixed;
    top: 3px;
    right: 10px;
    z-index: 99999;
    font-size: 10px;
}
.modal-2__content {
    max-height: 100vh;
    overflow-y: auto;
    padding: 20px 10px 0 10px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
}
.modal-2__content img{
	display: block;
/*	transition:1s all;*/
	max-width: 100%;
	height: auto;
}
.modal-2__content img:hover{
  transform: none;
  transition: none;
}
.modal-2__content p{
  padding: 30px 0;
}


.modal-2__background {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .45);
    z-index: 1;
}
/*モーダル背景　01-12*/
.modal-2__background-1 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_1bg.jpg);*/
  z-index: 1;
}
.modal-2__background-2 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_2bg.jpg);*/
  z-index: 1;
}
.modal-2__background-3 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_3bg.jpg);*/
  z-index: 1;
}
.modal-2__background-4 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_4bg.jpg);*/
  z-index: 1;
}
.modal-2__background-5 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_5bg.jpg);*/
  z-index: 1;
}
.modal-2__background-6 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_6bg.jpg);*/
  z-index: 1;
}
.modal-2__background-7 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_7bg.jpg);*/
  z-index: 1;
}
.modal-2__background-8 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_8bg.jpg);*/
  z-index: 1;
}
.modal-2__background-9 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_9bg.jpg);*/
  z-index: 1;
}
.modal-2__background-10 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_10bg.jpg);*/
  z-index: 1;
}
.modal-2__background-11 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_11bg.jpg);*/
  z-index: 1;
}
.modal-2__background-12 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
/*  background-image: url(../img/contents_03_12bg.jpg);*/
  z-index: 1;
}
/*モーダル背景　01-12*/




@keyframes modal-2-animation {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@media only screen and (max-width: 520px) {

}
/* =========== GALLERY =========== */







/* =========== ハイブリッドスクロール =========== */
/*
article h2 {
  text-align: center;
}
.horizontal_scroll {
  --sticky-container-height: 100vh;
  height: var(--sticky-container-height);
  min-height: 100vh;
  box-sizing: border-box;
}
.horizontal_scroll .sticky {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
}
.horizontal_scroll .scroller {
  display: flex;
  overflow: auto;
}
.horizontal_scroll .scroller.nobar {
  overflow: hidden;
}
.horizontal_scroll .scroller > * {
  flex-basis: 66%;
  flex-shrink: 0;
  aspect-ratio: 16 / 9;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: whitesmoke;
}
.horizontal_scroll .scroller > *:not(:first-child) {
  margin-left: 1%;
}
*/
/* =========== ハイブリッドスクロール =========== */






/* =========== ハイブリッドスクロール =========== */
article h2 {
  text-align: center;
}
.horizontal_scroll {
  --sticky-container-height: 100vh;
  height: var(--sticky-container-height);
/*  min-height: 0vh;*/
  box-sizing: border-box;
}
.horizontal_scroll .sticky {
  position: sticky;
  top: 0;
/*  display: flex;
  flex-direction: column;
  justify-content: center;*/
  /*min-height: 100vh;*/
}
.horizontal_scroll .scroller {
  display: flex;
  overflow: auto;
}
.horizontal_scroll .scroller.nobar {
  overflow: hidden;
}
.horizontal_scroll .scroller > * {
  flex-basis: 100%;
  flex-shrink: 0;
/*  aspect-ratio: 16 / 9;*/
  aspect-ratio: 4 / 3;
  display: flex;
  justify-content: center;
  align-items: center;
/*  background-color: whitesmoke;*/
/*  border-left: solid 1px #49bbbc;*/
}
.horizontal_scroll .scroller > *:first-child {
/*  border-left: solid 1px #fff;*/
}
.horizontal_scroll .scroller > *:not(:first-child) {
  margin-left: 1%;
}
/* =========== ハイブリッドスクロール =========== */




/* =========== コンセプト =========== */

/*---------A---------*/
.point_text_box{
  padding: 10% 0 0 5%;
}
.point_img_box .point_img1{
  width: 40%;
  text-align: right;
  position: absolute;
  right: 0;
  bottom: 40%;
}
.point_img_box .point_img2{
  width: 65%;
  text-align: right;
  position: absolute;
  left: 10%;
  bottom: 20%;
}
.point_img_box .point_img3{
  width: 50%;
  text-align: right;
  position: absolute;
  right: 0;
  bottom: 5%;
}

@media only screen and (max-width: 48em) {
.point_img_box .point_img1{
  width: 45%;
  bottom: 50%;
}
.point_img_box .point_img2{
  width: 75%;
}
.point_img_box .point_img3{
  width: 55%;
}
}
/*
div {
  box-sizing: border-box;
  color: #FFF;
  font-size: 5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 5%;
}
*/

h2 {
    font-family: 'Impact';
    font-size: 55px;
    text-align: center;
}

.cd-fixed-bg {
    position: relative;
    min-height: 100%;
    background-size: cover;
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-position: center center;
    z-index: 2;
}
.cd-fixed-bg p{
  color: #fff;
  font-size: 20px;
  font-weight: 500;
/*text-align: center;*/
  letter-spacing: 2px;
}
@media only screen and (max-width: 48em) {
.cd-fixed-bg p{
  font-size: 16px;
/*  text-align: center;
  padding: 20% 0 10% 0;*/
}
}

.cd-fixed-bg.cd-bg-1  {
  background-image: url(../img/concept_01_01.jpg);
  height: 100vh;
}
.cd-fixed-bg.cd-bg-2  {
  background-image: url(../img/concept_01_02.jpg);
  height: 100vh;
}
.cd-fixed-bg.cd-bg-3  {
  background-image: url(../img/concept_01_03.jpg);
  height: 100vh;
}
.cd-fixed-bg.cd-bg-4  {
  background-image: url(../img/concept_01_04.jpg);
  height: 100vh;
}

/*-------- ▼ スマホに対応 ▼ --------*/
@media screen and (max-width: 736px) {
	.cd-fixed-bg {
		background-size: cover;
		background-attachment: scroll;
	}
}
/*---------A---------*/


/*---------B---------*/

.point_text_box2{
  text-align: center;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.5px;
}

h5 {
  text-align: center;
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 1px;
  font-weight: bold;
  border-top: #fff solid 2px;
  border-bottom: #fff solid 2px;
  margin-bottom: 20px;
  padding: 10px 0;
}
/*---------B---------*/


/*---------C---------*/
.concept_area{
  padding: 0 10%;
  position: relative;
}
.concept_area p{
  font-size: 22px;
  text-align: center;
  margin: auto;
  font-weight: bold;
  letter-spacing: 1;
}
.concept_box img{
  border: #fff solid 3px;
  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.15);
  vertical-align: middle;
  filter: blur(10px);
  opacity: 0;
  transition: all .5s ease-in-out .5s;
}
.concept_box img.img01{
  transform: rotate(10deg);
  position: relative;
  right: 10px;
  margin-bottom: 20px;
}
.concept_box img.img02{
  transform: rotate(-10deg);
  position: relative;
  right: -10px;
  margin-bottom: 20px;
}
.concept_box img.img03{
  transform: rotate(2deg);
  position: relative;
  right: -5px;
  margin-bottom: 20px;
}

.concept_txt_01 img{
  position: absolute;
  bottom: 220px;
  right: -20px;
  width: 28%;

  vertical-align: middle;
  filter: blur(10px);
  opacity: 0;
  transition: all .3s ease-in-out .3s;
}
.concept_txt_02 img{
  position: absolute;
  bottom: 220px;
  left: -20px;
  width: 28%;

  vertical-align: middle;
  filter: blur(10px);
  opacity: 0;
  transition: all .3s ease-in-out .3s;
}
.concept_txt_03 img{
  position: absolute;
  bottom: 210px;
  right: -20px;
  width: 28%;

  vertical-align: middle;
  filter: blur(10px);
  opacity: 0;
  transition: all .3s ease-in-out .3s;
}

@media only screen and (max-width: 48em) {
.concept_txt_01 img{
  position: absolute;
  bottom: 200px;
  right: -20px;
  width: 28%;
  z-index: 10;
}
.concept_txt_02 img{
  position: absolute;
  bottom: 200px;
  left: -20px;
  width: 28%;
}
.concept_txt_03 img{
  position: absolute;
  bottom: 200px;
  right: -20px;
  width: 28%;
}  
}

/*
.view{
    position: relative;
    overflow: hidden;
}*/
/*
.view img{
    vertical-align: middle;
    filter: blur(10px);
    opacity: 0;
    transition: all .5s ease-in-out .5s;
}*/
.view.js-on img{
    filter: blur(0px);
    opacity: 1;
}

/*---------C---------*/


/* =========== コンセプト =========== */






/* =========== 5つのポイント =========== */
.point_box{
	display: flex;
	flex-direction: column;
	padding: 5% 0 20% 0;
  /*margin: 10% 0;*/
  /*background-color: #fff;*/
  border-radius: 20px;
  /*box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.1);*/
  width: 90%;
  height: auto !important;
}
.point_box .point_img{
/*	width: 320px;*/
	text-align: center;
	margin: auto;
  margin-bottom: 10%;
/*  border: solid 30px #e1eded;*/
   filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.25));
}
.point_box .point_title{
	width: 50%;
	text-align: left !important;
  box-shadow: none;
}

h3{
 font-size: 35px;
 letter-spacing: 0.3rem;
 color: #000;
 font-weight: normal;
}
h3 span{
 font-size: 45px;
}

.point_text p{
	font-size: 15px;
  font-weight: 500;
  text-align: center;
  padding: 0 30px;
}
.point_text p span{
	font-size: 22px;
  line-height: 30px;
  font-weight: bold;
}
.point_text h3{
	border-bottom: #49bbbc solid 1px;
  margin: auto;
  width: 100%;
}
@media only screen and (max-width: 48em) {
.point_text p span{
	font-size: 20px;
}  
}

.point_area{
  /*
  border-top-left-radius: 240px; 
  border-top-right-radius: 240px;
  padding: 20% 0 0 0;
  */
}
/* ===========　5つのポイント =========== */






/* =========== THANKS VOICE =========== */

/* THANKS VOICE */
.swiper-slide {
  margin: 20px 0;
	background-color: #ffffff;
  border-radius: 10px;
  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.15);
	padding: 25px 10px;
	text-align: center;
/*  border: solid 1.5px #d2b573;*/
}
.swiper-slide h2{
	writing-mode: horizontal-tb;
	font-size: 19px;
	font-weight: bold;
	color: #d2b573;
	display: inline-block;
}


/*====スライダ―====*/
    .slider{
        width:100%;
        margin:0 auto;
    }
    .slider .slick-slide{
        height:auto!important;
        margin-right: 1vw!important;
        margin-left: 1vw!important;
        height: auto !important;
    }
    .slider .slick-arrow{
        z-index:2!important;
    }
    .slider .slick-next{
        right:0!important;
    }
    .slider .slick-prev{
        left:0!important;
    }
/*====スライダ―====*/

/* =========== THANKS VOICE スライダ― =========== */








/* =========== PLAN =========== */
.small_plan_container{
}
.small_plan_area{
 background-color: #fff;
 padding: 10px;
 text-align: center;
 margin: auto;
 box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.15);
 border: solid 1px #d2b573;
 border-radius: 10px;
}
/*
.small_plan_area h3{
  text-align: left;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif !important;
  font-weight: bold;
  color: #333 !important;
  padding: 10px 0 ;
}
*/
.small_plan_box {
  width: 100%;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif !important;
}
.small_plan_box .price{
  font-size: 13px;
  letter-spacing: 0.8px;
  margin-bottom: 30px;
}
.small_plan_box .price span{
  font-size: 18px;
  font-weight: 500;
}
p .notes{
  font-size: 12px;
  line-height: 2rem;
}
@media only screen and (max-width: 48em) {
.small_plan_container{
/*  background-color: transparent !important;/*背景透過*/
}  
}

.plan-title_box{
 background-color: #f5f5f5;
 text-align: center;
 padding: 5px;
}
.plan-title_box p{
 font-size: 18px;
 font-weight: 500;
}
.plan-title_box p span{
 font-size: 13px;
 color: #d2b573;
}
h4{
  font-size: 20px;
  padding: 15px 0 0 0;
}
h4 span{
  font-size: 14px;
  font-weight: bold;
}
.small_plan_box .plan_text{
  font-size: 18px;
  padding: 15px 0;
  font-weight: bold;
}
.small_plan_box .plan_text span{
  font-size: 22px;
  color: #d2b573;
}

/*===== プラスマーク =====*/
.dli-plus {
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  width: 1em;
  height: 0.1em;
  background: currentColor;
  border-radius: 0.1em;
  position: relative;
}
.dli-plus::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: inherit;
  border-radius: inherit;
  transform: rotate(90deg);
}
/*===== プラスマーク =====*/

/* =========== PLAN =========== */









/* =========== CBRについて =========== */
.style_box{
  margin-bottom: 0;
}
.style_area{
  padding: 0;
}
.style_area h3{
  color: #7acdd026;
  font-size: 70px;
  position: relative;
  left: -25px;
  top: 30px;
  line-height: 50px;
}
.style_box img{
  display: block;
/*  border-radius: 15px 0 0 15px;*/
}
.style_box2 img{
  display: block;
  border-radius: 10px;
/*  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.15);*/
}
.style_band{
  /*background-image: linear-gradient(0deg, rgba(253, 226, 157, 1), rgba(73, 187, 188, 1));*/
  background-color: #49bbbc;
  color: #fff;
  writing-mode: vertical-rl;
  padding: 0 5px;
}
.style_band p{
  font-weight: 500;
  letter-spacing: 0.1em;
}
.style_band p span{
  font-size: 30px;
}
.style_text{
  border-bottom: solid 1px #49bbbc;
  font-size: 20px;
  padding: 10px 10px 10px 0;
  line-height: 1.2;
  margin-bottom: 3rem;
}
.style_text span{
  color: #49bbbc;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.5px;
}
@media only screen and (max-width: 48em) {
.style_text{
  line-height: 1.5;
}
.style_area h3{
  font-size: 60px;
  line-height: 60px;
  top: 35px;
}
}


/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■　画面分割　片側固定　■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/*========= 左固定レイアウトのためのCSS ===============*/

/*左と右を囲う全体のエリア*/
#wrapper{
  position: relative;/*position stickyの基点にするため relativeをかける*/
  display: flex;/*左エリア、右エリア横並び指定*/
  flex-wrap: wrap;/*ボックスの折り返し可*/
  justify-content: space-between;
}

/*左エリア*/
#fixed-area{
  /*左固定記述*/
  position: -webkit-sticky;/*Safari用*/
  position: sticky;
  top:0;
 /* width: 50%;/*横半分50%　縦を100vhにする*/
  height: 100vh;
  /*装飾のためのCSS*/
  display: flex;
/*  justify-content: center;*/
  text-align: center;
/*  align-items: center;*/
/*  background:url(../../top/movie/dummy.jpg) no-repeat center;*/
  background-size:cover;
  color:#fff;
  font-size: 20px;
}

/*右エリア*/
#container{
  width:80%;/*横半分50%にする*/
  margin-top: 7%;
}
/*右各セクション 装飾のためのCSS*/
section{
/*  min-height: 100vh;*/
/*   padding: 0 30px;*/
}

/*
section:nth-of-type(2n){
/*装飾のためのCSS*/
/*  background:#eee;
}
*/

@media only screen and (max-width: 30em) {
section.topics-box_area{
  padding: 0;
}  
}


/*右から画像が表示される*/
.fade-in_right {
  opacity: 0;
}

.img-animation {
  animation: img-opacity 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  overflow: hidden;
  position: relative;
}

.img-animation::before {
  animation: img-animation 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  background: #fff;
  content: '';
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

@keyframes img-opacity {
  100% {
    opacity: 1;
  }
}

@keyframes img-animation {
  100% {
    transform: translateX(-100%);
  }
}
/* =========== CBRについて =========== */



/* =========== バンケット紹介 =========== */
.style_area{
}
.banquet_title{
  border-top: #49bbbc solid 2px;
  border-bottom: #49bbbc solid 2px;
  color: #49bbbc;
  font-size: 20px;
  font-weight: bold;
  padding: 10px 0; 
  text-align: center;
  line-height: 25px;
}
.banquet_title span{
  font-size: 16px;
}
.style_area .banquet_title-en{
  font-size: 23px;
  color: #000;
  letter-spacing: 1px;
  margin: auto;
  text-align: center;
}
.style_area .banquet_title-en span{
  font-size: 28px;
}
.style_area .banquet_title-jpn{
  font-size: 12px;
  color: #000;
  text-align: center;
}
.banquet_text-box{
  margin: 10px;
  text-align: center;
}
.banquet_text-box2 p{
  padding: 20px 5px 0 5px;
}
.banquet_text-box2 p{
  font-size: 15px;
  line-height: 2.5rem;
  font-weight: 500;
  letter-spacing: 0.3px;
}
/* =========== バンケット紹介 =========== */



/* =========== 共通 =========== */
br.mb_show {
	display: none;
}
br.pc_show {
	display: block;
}
/* 480px */
@media only screen and (max-width: 30em) {
br.mb_show {
	display: block;
}
br.pc_show {
	display: none;
}
}

/* 下からふわっとアニメーション設定 */
.animation {
  opacity: 0;
  transform: translate3d(0, 30px, 0);
}
.animation.is-active {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: 0.8s;
}

.text_6{
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.2rem;
}
/* =========== 共通 =========== */




/* =========== ACCESS =========== */

.access_box{
  border: solid 1px #444;
  background-color: #fff;
  padding: 5%;
  /*box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);*/
}
.access_text{
  font-weight: bold;
  font-size: 18px;
  padding-top: 10px;
}

.access_text2{
  background-color: #49bbbc;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  padding: 5px 0;
}
.text_4{
  font-size: 15px;
  font-weight: bold;
  color: #ba9867;
}
.text_4 span.typeB{
  font-size: 20px;
}
.text_4 span.typeC{
  font-size: 25px;
}

/* =========== ACCESS =========== */




/* =========== ABOUT US =========== */
.p-gallery__list {
  margin: 3.75rem -0.39vw -0.78vw;
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
}
.p-gallery__item {
  width: calc(25% - 0.86vw);
  margin: 0 0.4vw 0.79vw;
  box-sizing: border-box;
}
.p-gallery__item a img {
  transition: transform ease 0.8s;
}
.c-animate--animated {
  opacity: 1.0;
  transform: translate(0, 0);
}
.p-galleryPopup .fancybox-button {
  background: transparent;
}
.fancybox-outer, .fancybox-inner, .fancybox-bg, .fancybox-stage {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
/* =========== ABOUT US =========== */




/* =========== 吹き出し =========== */
.fukidashi-01 {
  position: relative;
  padding: 12px 16px 12px 30px;
}
.fukidashi-01::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 20px;
  width: 80px;
  height: 2px;
  transform: rotate(-14deg);
  box-sizing: border-box;
  background-color: #fffcf6;
}
.fukidashi-01::after {
  content: "";
  position: absolute;
  bottom: -14px;
  left: 20px;
  width: 90px;
  height: 2px;
  transform: rotate(14deg);
  box-sizing: border-box;
  background-color: #fffcf6;
}
.fukidashi-01 > .ornament {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.fukidashi-01 > .ornament::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 20px;
  width: 120px;
  height: 2px;
  transform: rotate(-12deg);
  box-sizing: border-box;
  background-color: #fffcf6;
}
.fukidashi-01 > .ornament::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 20px;
  width: 120px;
  height: 2px;
  transform: rotate(12deg);
  box-sizing: border-box;
  background-color: #fffcf6;
}




.fukidashi-02 {
  position: relative;
  width: fit-content;
  padding: 16px 10px;
  border-top: 1px solid #333333;
  border-bottom: 1px solid #333333;
  background-color: #fffcf6;
  text-align: center;
  margin: 30px auto 0;
}
/*
.fukidashi-02::before {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  width: 15px;
  height: 15px;
  box-sizing: border-box;
  background-color: #fffcf6;
  rotate: 135deg;
  translate: -50%;
}
*/
.fukidashi-02::after {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  /*z-index: -1;*/
  width: 15px;
  height: 15px;
  box-sizing: border-box;
  border: 1px solid;
  border-color: #333333 #333333 transparent transparent;
  background-color: #fffcf6;
  rotate: 315deg;
  translate: -50%;
}


.fukidashi-03 {
  position: relative;
  width: fit-content;
  padding: 16px 10px;
  border-top: 1px solid #333333;
  border-bottom: 1px solid #333333;
  background-color: #f5f5f5;
  text-align: center;
  margin: 30px auto 0;
}
.fukidashi-03::after {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  /*z-index: -1;*/
  width: 15px;
  height: 15px;
  box-sizing: border-box;
  border: 1px solid;
  border-color: #333333 #333333 transparent transparent;
  background-color: #f5f5f5;
  rotate: 315deg;
  translate: -50%;
}
/* =========== 吹き出し =========== */





