@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;
  right: -20%;
  box-shadow: 0px 0px 20px 3px rgba(0, 0, 0, 0.2);
}
.mainvisual {
	background-image: url(../img/mainvisual.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	height: 100vh;
}
.mainvisual:after {
	display: none;
}
@media only screen and (max-width: 48em) {
.mainvisual {

}
article.page-base {
  right: 0;
  box-shadow: none;
}
}


.header-neo-inner h1 {
	text-align: left;
}
.header-neo-inner h2 {
	font-size: 20px;
  color: #444;
  line-height: 1.7em;
}
.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{
  color: #49bbbc;
  font-size: 30px;
  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%;
}

@media only screen and (max-width: 48em) {
.flex_2A div, .flex_2A section{
	width: 48%;
	margin: 0 0 0 0;
}
}

.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;
}




/* コンテンツ一覧 */
.contents_box {
	text-align: center;
  padding: 0 5%;
}
.contents_box h2{
	writing-mode: horizontal-tb;
  font-size: 20px;
  color: #fff;
  background-color: #49bbbc;
  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;
}

/* アバウト */
.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;
}
.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: 120px;
	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_beige { background-color: #fffcf6 !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: 1.5rem;
  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: 150px;
  height: 77px;
  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;
	background: #000;
  opacity: 0.8;
  box-shadow: 0 2px 8px -1px rgb(200 200 200 / 50%), 0 0 12px #000;
  padding: 10px 0;
}


/* footerリンクボタン */
.footer_btn{
  display: flex;
  justify-content: space-evenly;
}
.footer_btn_inner{
  background-color: #ba9867;
  border-radius: 5px;
  width: 30%;
  padding: 0 5px;
}
.footer_btn_inner img{
  width: 100%;
}
/* footerリンクボタン */




/* いつでも見学予約 */
.btn_area2{
text-align: center;
margin: auto;
padding: 5% 0;
}
.fair_more{
  padding: 0 5%;
}
.text_box_E{
  padding: 15px 0 0;
  border-radius: 7px;
  text-align: center;
  box-shadow: inset 0px 0px 6px 0px rgba(0, 0, 0, 0.2);
}
.text_5{
  font-size: 13px;
  font-weight: bold;
  color: #9b7e55;
}
a.btn_03 {
	display: block;
	text-align: center;
	width: 250px;
	margin: auto;
	padding: 1rem;
	font-weight: bold;
	color: #fff;
	border: 1.5px solid #9b7e55;
	transition: 0.5s;
  background-color: #ba9867;
  letter-spacing: 0.1em;
  border-radius: 2px;
  transition: 0.5s;
  text-decoration: none;
}
a.btn_03:hover {
	opacity: 0.5;
}
@media only screen and (max-width: 48em) {
a.btn_03 {
	width: 200px;
}  
}

/* ====== 吹き出し ====== */
.fukidashi-01 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  color: #49bbbc;
}
.fukidashi-01::before {
  content: "";
  width: 30px;
  height: 2px;
  transform: rotate(60deg);
  box-sizing: border-box;
  background-color: #49bbbc;
}
.fukidashi-01::after {
  content: "";
  width: 30px;
  height: 2px;
  transform: rotate(-60deg);
  box-sizing: border-box;
  background-color: #49bbbc;
}
.text_6{
  font-size: 13px;
  padding: 15px 0;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
}
/* ====== 吹き出し ====== */

/* いつでも見学予約 */









/* 電話番号 */
.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;
}

.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: #fff;
  border-radius: 0.5rem;
  background-color: #49bbbc;
}
.Btn_01 span{
  font-size: 1.3rem;
}
a.btn--blue.btn--cubic {
  border-bottom: 5px solid #179597;
}

a.btn--blue.btn--cubic:hover {
  margin-top: 3px;
  border-bottom: 2px solid #179597;
}

a.btn--radius {
  border-radius: 100vh;
}

.fa-position-right {
  position: absolute;
  top: calc(50% - .5em);
  right: 1rem;
}

/*============= Btn =============*/






/* =========== ABOUT US =========== */

.img_box04 {
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
	justify-content: space-between;
	width: 100%
}
.img_box04_inner {
    margin-bottom: 1%;
	position: relative;
	overflow:hidden;
	width: calc(33.5% - 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: #777;*/
    color: #fff;
  /*  border: 2px solid #fff;*/
    border-radius: 20px;
  /*  width: 36px;
    height: 36px;*/
    line-height: 1.6;
    text-align: center;
    display: table-cell;
    position: fixed;
    top: -52px;
    right: 0%;
    z-index: 99999;
    font-size: 3em;
}
.modal-2__content {
    max-height: 100vh;
    overflow-y: auto;
}
.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: 20px 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) {

}
/* =========== ABOUT US =========== */







/* =========== ハイブリッドスクロール =========== */
/*
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: 2;
  letter-spacing: 1px;
}
@media only screen and (max-width: 48em) {
.point_text_box2{
  font-size: 15px;
}  
}
h5 {
  text-align: center;
  font-size: 20px;
  line-height: 2;
  letter-spacing: 1.5px;
  font-weight: 500;
  color: #444;
}
h6 {
  text-align: center;
  font-size: 20px;
  line-height: 2;
  letter-spacing: 1.5px;
  font-weight: 500;
  color: #444;
}
/*---------B---------*/





/* =========== コンセプト =========== */






/* =========== 4つのポイント =========== */
.point_box{
	display: flex;
	flex-direction: column;
	padding: 15% 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;
/*  box-shadow: 20px 20px 0 rgba(122, 208, 197, 0.2);*/
/*  border: solid 30px #e1eded;*/
}
.point_box .point_title{
	width: 50%;
	text-align: left !important;
  box-shadow: none;
}

h3{
 font-size: 35px;
 color: #49bbbc;
 font-weight: normal;
 font-style: italic;
 text-align: left;
/* border-bottom: solid 1px #49bbbc;*/
}
h3 span{
 font-size: 50px;
}
.point_text p{
	font-size: 15px;
  font-weight: 500;
  margin-top: 5%;
  text-align: center;
}
.point_text p span{
	font-size: 25px;
  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;
}  
}

/* ===========　4つのポイント =========== */






/* =========== THANKS VOICE =========== */

/* THANKS VOICE */
.swiper-slide {
  margin: 20px 0;
	background-color: #ffffff;
  /*border: solid 1px #ba9867;*/
  box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.1);
	padding: 25px 10px;
	text-align: center;
}
.swiper-slide h2{
	writing-mode: horizontal-tb;
	font-size: 19px;
	font-weight: bold;
	color: #ba9867;
	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;
    }
/*====スライダ―====*/



/*----- ノート風罫線 -----*/
.txtbox {
  width: 90%;
	margin: auto;
  background-color: #fff; /* 背景色 */
  background-image: linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%), /* 点線1の色 */
                    linear-gradient(180deg, #ccc 1px, transparent 1px); /* 点線2の色と太さ */
  background-size: 8px 100%, /* 点線1のサイズ */
                   100% 2.5em; /* 点線2のサイズ */
  line-height: 2.5em; /* 文字の高さ */
  padding-bottom: 1px; /* 最終行の下にも罫線を引く */
}
.txtstyleA {
	font-size: 13px;
}

/* =========== THANKS VOICE スライダ― =========== */




/* =========== PLAN =========== */
.plan_box_1{
  padding: 5%;
  border: #555 solid 2px;
  border-radius: 7px;
}
.plan_box_2{
  padding: 5%;
  border: #49bbbc solid 2px;
  border-radius: 7px;
}
.plan_txt{
  font-size: 18px;
  letter-spacing: 0.1rem;
  font-weight: bold;
}
.plan_box_title_1{
  background-color: #d3d3d3;
  padding: 10px 0;
  border-radius: 7px;
}
.plan_box_title_1 p{
  font-size: 18px;
  letter-spacing: 0.1rem;
  font-weight: bold;
}
.plan_box_title_2{
  background-color: #49bbbc;
  padding: 10px 0;
  border-radius: 7px;
}
.plan_box_title_2 p{
  font-size: 18px;
  color: #fff;
  letter-spacing: 0.1rem;
  font-weight: bold;
}

.plan_flex {
  display: flex;
  align-items: center;
  padding: 10px 0;
  justify-content: space-around;
}
.plan_flex img{
  width: 20%;
}
.plan_flex p{
  width: 70%;
  font-size: 18px;
  letter-spacing: 0.1rem;
  font-weight: bold;
  text-align: left;
}

/* 三角矢印 */
.arrow{
  width: 30px;
  height: 30px;
  border: 3px solid;
  border-color:  transparent transparent #49bbbc #49bbbc;
  transform: rotate(-45deg);
  text-align: center;
  margin: 0 auto 20px;
}


p .notes{
  font-size: 12px;
  line-height: 2rem;
}
@media only screen and (max-width: 48em) {
.plan_container{
/*  background-color: transparent !important;/*背景透過*/
}  
}

/*====アコーディオン====*/
.accordion-003 {
  max-width: 100%;
  margin: auto 5%;
  border-bottom: 1px solid #49bbbc;
  text-align: center;
  transition: transform .5s, opacity .5s;
}

.accordion-003 summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding: 1em 0.5em;
  color: #49bbbc;
  font-weight: 600;
  cursor: pointer;
  font-size: 18px;
}

.accordion-003 summary::-webkit-details-marker {
  display: none;
}

.accordion-003 summary::after {
  transform: translateY(-25%) rotate(45deg);
  width: 7px;
  height: 7px;
  margin-left: 10px;
  border-bottom: 3px solid #49bbbc;
  border-right: 3px solid #49bbbc;
  content: '';
  transition: transform .3s;
}

.accordion-003[open] summary::after {
  transform: rotate(225deg);
}

.accordion-003 p {
  transform: translateY(-10px);
  opacity: 0;
  margin: 0;
  color: #000000;
  transition: transform .5s, opacity .5s;
}

.accordion-003[open] p {
  transform: none;
  opacity: 1;
}
/*====アコーディオン====*/



h4.plan_title{
    position: relative;
    padding: 0.8rem 0;
    margin-bottom: 0.2rem;
    border-bottom: 3px solid;
    color: black;
    font-weight: bold;
    font-size: 24px;
    text-align: center;
}

h4.plan_title:before,
h4.plan_title:after {
    position: absolute;
    top: 100%;
    left: 50%;
    content: "";
    height: 0;
    width: 0;
}

h4.plan_title:before {
    border: 13px solid;
    border-color: transparent;
    border-top-color: black;
    margin-left: -13px;
}

h4.plan_title:after {
    border: 9px solid;
    border-color: transparent;
    border-top-color: white;
    margin-left: -9px;
}



/* =========== PLAN =========== */



/* =========== フェアコンテンツ =========== */
.fair_box{
  display: flex;
  background-color: #d7b974;
  border-radius: 10px;
  margin-bottom: 10px;
  justify-content: flex-start;
  height:auto;
 /* box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.15);*/
  box-shadow: 0px 0px 5px 1px rgba(0, 0, 0, 0.15);
}
.fair_box img{
 width: 45%;
 border-top-left-radius: 6px;
 border-bottom-left-radius: 6px;
 object-fit: cover;
}
.fair_text{
 padding: 12px;
}
.fair_box .text_1{
  font-size: 18px;
  font-weight: bold;
  border-top: solid 1px #fff;
  border-bottom: solid 1px #fff;
  margin-bottom: 10px;
  letter-spacing: 0.8px;
  line-height: 40px;
  color: #fff;
}
.fair_box .text_2{
 font-size: 14px;
/* font-weight: bold;*/
 line-height: 1.5em;
 color: #fff;
}

@media only screen and (max-width: 48em) {
  .fair_box .text_1{
    font-size: 14px;
  }
  .fair_box .text_2{
   font-size: 13px;
  }
}


.fair_heading{
  margin-bottom: 20px;
}
.fair_heading p.txt_A{
  font-size: 15px;
  font-weight: bold;
  color: #d7b974;
}
.fair_heading p.txt_B{
  font-size: 25px;
  color: #d7b974;
  font-weight: bold;
}
@media only screen and (max-width: 48em) {
.fair_heading p.txt_B{
  font-size: 23px;
}
}




/* 吹き出し */
.speechBubble {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: 10px 20px;
  border: 2px solid #d7b974;
  border-radius: 35px;
  background-color: #fffcf6;
  text-align: left !important;
  line-height: 1.5;
}
.speechBubble::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 15px 10px 0 10px;
  border-color: #d7b974 transparent transparent;
  translate: -50% 100%;
}
.speechBubble::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 11.4px 7.6px 0 7.6px;
  border-color: #fffcf6 transparent transparent;
  translate: -50% 100%;
}


/* =========== フェアコンテンツ =========== */





/* =========== 選べるWeddingstyle =========== */
.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;
/*  margin: 3rem 0;*/
}
.style_band{
/*  background-image: linear-gradient(0deg, rgba(253, 226, 157, 1), rgba(73, 187, 188, 1));*/
  background-image: linear-gradient(0deg, rgb(253, 241, 211), rgb(212, 206, 167));
  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: 18px;
  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: 10%;/*横半分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: 5%;
}
/*右各セクション 装飾のための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%);
  }
}
/* =========== 選べるWeddingstyle =========== */



/* =========== バンケット紹介 =========== */
.style_area{
  padding: 0;
}
.style_area .banquet_title-en{
  border-bottom: solid 1px #49bbbc;
  font-size: 18px;
  color: #49bbbc;
  font-weight: bold;
  letter-spacing: 1px;
  width: 200px;
  margin: auto;
}
.style_area .banquet_title-jpn{
  font-size: 12px;
  margin-top: 5px;
}
.banquet_text-box{
  margin: 10px 0;
}
.style_area .banquet_text{
  font-size: 15px;
  margin-bottom: 5px;
}

/* =========== バンケット紹介 =========== */



/* =========== 共通 =========== */
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, 50px, 0);
}
.animation.is-active {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: 0.8s;
}

.marker{
 background: linear-gradient(transparent 70%, #fffb82 70%); 
}
.marker2{
 background: linear-gradient(transparent 50%, #eae4d2 70%); 
}

/* =========== 点滅 =========== */
@keyframes blinking {
   0% {
   opacity: 0;
   }
   100% {
   opacity: 1;
   }
}

/* 要素にアニメーションを適用 */
.blink {
   animation: blinking 1s ease-in-out infinite alternate;
}
/* =========== 点滅 =========== */


/* =========== 共通 =========== */




/* =========== ACCESS =========== */

.access_box{
  border: solid 1px #444;
  background-color: #fff;
  padding: 5%;
}
.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 =========== */


/*=== 一定量通過したらbtn表示 ===*/
.btn_display {
position: fixed;
}