@charset "UTF-8";

html { scroll-behavior: smooth;}
body {
/*	background-image: url(../img/background.jpg); */
    background-color:rgba(255,255,255,0.2);
    background-blend-mode:darken;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	background-attachment: fixed;
	height: 100vh;    
	background-image: linear-gradient(90deg, rgb(58, 58, 58), rgb(0, 0, 0) 30%, rgb(93, 126, 42));
}
.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.5);
}
.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;
}

.header-neo-inner h3 {
	font-size: 16px;
    color: #333;
    font-style: normal;
    text-align: center;
    letter-spacing: 0.2rem;
    line-height: 2.2;
}


.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{
  margin-left: 5%;
}
.contents_text h2 span{
  color: #49bbbc;
  font-size: 30px;
  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;
	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: 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;
}

/* オープニングテキスト */

.logo_box img {
 width: 200px;
}

/* 垂直線　*/
.holizon_boder {
    padding-bottom: 10px;
}
.holizon_boder::after {
    display: block;
    content: "";
/*    position: absolute; */
    top: -210px;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 1px;
    height: 80px;
    background-color: #000000;
    padding-bottom: 80px;
}

/* 水平線　*/
.virtical_boder {
  width: 70px;
  border-top: 3px solid #5d7e2a;
}


/* 英字見出し01　*/
p.MainContentBlock-headTitle span{
	font-family: "Julius Sans One" !important;
	font-weight:400 !important;
	font-size:34px;
	letter-spacing:normal;
}
.MainContentBlock-subTitle {
  font-size: 1.4rem;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
  margin-top: 0;
}
.MainContentBlock-headTitle span::after, .MainContentBlock-headTitle.ja span::after {
    display: block;
    width: 100%;
    height: 0px;
    background-color: #FFF; 
    content: "";
}

.caption_txt{
  text-align: center;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
}

.caption_txt_mid{
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
}


/* アバウト */
.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: 0px;
	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;*/
  width: 49.3%;
  padding: 15px 0;
  color: #fff;
  marign:auto;
  display: inline-block;
  white-space: wrap;
}

.navi_boder {
  border-right: 1px solid #fff;
  padding: 5px 0;
}

.btn_flex {
	position: fixed !important;
	top: 0;
	z-index: 5000;
	width: 100%;
	max-width: 480px;
	background: #000;
    opacity: 0.8;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 2px 8px -1px rgb(200 200 200 / 50%), 0 0 12px #000;
}

/*============= Btn =============*/
.btn_area{
text-align: center;
margin: auto;
/*border-radius: 5px;
  background-image: linear-gradient(0deg, rgba(230, 232, 200, 1), rgba(244, 245, 229, 1));
/* border: 1px solid #ddd; */
padding: 15px 5px 15px !important;
/* margin: 0 5% !important; */
}

.Btn_01,
a.Btn_01,
button.Btn_01 {
  font-size: 1.3rem;
  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.8rem;
  background-color: #587728;
}
.Btn_01 span{
  font-size: 1.2rem;
}
a.btn--blue.btn--cubic {
  border-bottom: 3px solid #534e4c;
}

a.btn--blue.btn--cubic:hover {
  margin-top: 3px;
  border-bottom: 0 solid #534e4c;
}

/*
a.btn--radius {
  border-radius: 100vh;
} */

.fa-position-right {
  position: absolute;
  top: calc(50% - .5em);
  right: 1rem;
}

.btn_box01 {
  position: relative;
  width: fit-content;
  padding: 8px 16px;
  border-bottom: 1px solid #587728;
  background-color: #fff;
  text-align: center;
  margin: 15px auto 10px;
}

p.btn_box01_txt01 {
  font-size: 14px;
  font-weight: bold;
  color:#587728;
}

.btn_box01::before {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  width: 14px;
  height: 15px;
  box-sizing: border-box;
  background-color: #ffffff; /* 背景色と同じ色を指定 */
  rotate: 135deg;
  translate: -50%;
}
.btn_box01::after {
  content: "";
  position: absolute;
  top: calc(100% + 5px);
  left: calc(50% - 10px);
  z-index: 0;
  width: 30px;
  height: 1px;
  transform: rotate(50deg);
  box-sizing: border-box;
  background-color: #587728;
  box-shadow: 0 2px 0 #ffffff, 0 -2px 0 #ffffff; /* 背景色と同じ色を指定 */
} 

/*============= Btn =============*/



/* 電話番号 */
.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;
}














a.Btn_06{
	border: 1px solid #49bbbc;
	color: #49bbbc;
	background-color: #fff;
	margin: 20px auto;
	padding: 8px 0;
	width: 400px;
	display: block;
	border-radius: 0;
    text-align: center;
    text-decoration: none;
    font-weight: bold;
    line-height: 3.39;
    transition-timing-function: linear;
    transition-duration: .2s;
    transition-property: background-color, color, opacity;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
a.Btn_06:hover {
    background-color: #49bbbc;
	color: #fff;
    }
@media only screen and (max-width: 48em) {
	a.Btn_06{
	border: 1px solid #49bbbc;
	color:  #fff;
	margin: 15px auto;
	width: 100%;
	background-color: #49bbbc;
	line-height: 5;
	font-size: 14px;
}
}



p.Btn_06 {
  position: relative;
  display: block;
  padding: .4em 3em;
  border: solid 1.5px #fff;
  color: #fff;
  text-align: center;
  text-decoration: none;
}
p.Btn_06::after {
  position: absolute;
  top: 50%;
  right: .2em;
  content: '';
  margin-top: -5px;
  border: 7px solid transparent;
  border-top-width: 5px;
  border-bottom-width: 5px;
  border-left-color: #fff;
  transition: all .2s;
}
@media only screen and (max-width: 48em) {
.img_box04_inner-Btn{
	top: 75%;
}
p.Btn_06 {
  position: relative;
  display: block;
  padding: 1em 3em;
  border: solid 1.5px #fff;
  color: #fff;
  text-align: center;
  text-decoration: none;
}
}









/* =========== 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: 80vh;
}
.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: 6% 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;
}

h5 {
  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: 6% 5%;
  margin: 20% 0;
  background-color: #fff;
  border-radius: 20px;
  box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.3);
  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%;
  box-shadow: none;
}


.point_text{
width: 100%;
}


.point_lead {
  font-size: 18px !important;
  padding-bottom: 20px !important;
}

.point_text p{
  font-size: 14px;
  font-weight: 500;
  text-align: center;
}
.point_text p span{
  font-size: 18px;
  padding: 20px;
}

.point_text h3{
  font-family: "Julius Sans One" !important;
  font-weight: 400 !important;
  font-size: 26px;
  letter-spacing: normal;
  font-style: normal;
  text-align: center;
  padding: 20px 0 10px ;
}



@media only screen and (max-width: 48em) {
.point_text p span{
	font-size: 18px;
}  
}

/* ===========　4つのポイント =========== */


/* ===========　特典=========== */
.special_favor_box{
background-color: #f7f4f4;
border: 1px solid #cccccc;
padding: 2%;
margin-bottom: 20px;
}

.faver_title{
  left: 38%;
  top:-40px;
  position: absolute;
  width: 90px;
  height: 90px;
  line-height: 26px;
  background-color: #5d7e2a;
  border-radius: 50%;
  color: #fff;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
  padding:18px;
}

.faver_title p{
font-size: 18px;
color: #fff;
font-weight: bold;
}


.favor_lead {
  font-size: 18px !important;
  letter-spacing: normal !important;
  font-style: normal !important;
  text-align: center !important;
  padding: 50px 0 10px;
  color: #333 !important;
}

.favor_lead span {
  font-size: 36px !important;
}

.favor_caption{
  font-size: 14px !important;
  padding: 5px 0 10px;
  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;
}



/* =========== 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;
    }
    .slider .slick-arrow{
        z-index:2!important;
    }
    .slider .slick-next{
        right:0!important;
    }
    .slider .slick-prev{
        left:0!important;
    }
/*====スライダ―====*/

/* =========== THANKS VOICE スライダ― =========== */




/* =========== PLAN =========== */
.plan_container{
}
.plan_area{
 background-color: #fff;
 border: solid 3px #49bbbc;
 padding: 5% 0;
 text-align: center;
 margin: auto;
 border-radius: 10px;
}
.plan_area h2{
  font-weight: bold;
  letter-spacing: 2px;
  color: #fff;
}
.plan_box {
	width: 100%;
	margin: 0 auto 20px;
	background-color: #f5f5f5;
	padding: 20px;
  border-radius: 10px;
}
.plan_box .price{
	font-weight: bold;
  font-size: 13px;
  letter-spacing: 0.8px;
  margin-bottom: 10px;
}
.plan_box .price span{
  font-size: 18px;
}
.plan_box p{
  font-size: 12px;
  line-height: 2.2rem;
}
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;
}
/*====アコーディオン====*/
/* =========== PLAN =========== */



/* =========== フェアコンテンツ =========== */

.fair_area{

}
.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: 20px;
  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: 18px;
  }
  .fair_box .text_2{
   font-size: 13px;
  }
}
/* =========== フェアコンテンツ =========== */





/* =========== 選べるWeddingstyle =========== */
.style_box{
  margin-bottom: 0;
}
.style_area{
  padding: 0;
}
.style_area h3{
  font-family: "Julius Sans One" !important;
  font-weight: 400 !important;
  font-size: 34px;
  letter-spacing: normal;
  font-style: normal;
  text-align: center;
  padding: 20px 0 10px ;
}
.style_area h3 span{
  font-size: 26px;
}

.style_area_sub{
  font-size: 16px;
  text-align: center;
  padding: 0px 0 30px;
  font-family: "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif !important;
  color: #333 !important;
}

.style_box img{
  display: block;
  margin: 5px 0;
}
.style_band{
  background-color: #5d7e2a;
  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{
	font-size: 16px;
    color: #333;
    font-style: normal;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.2rem;
    line-height: 2.2;
    margin-bottom: 20px;
}
.style_text span{
/*  color: #49bbbc; */
  font-size: 13px;
}

.style_text02{
	font-size: 12px;
    color: #333;
    font-style: normal;
    font-weight: bold;
    text-align: center;
    line-height: 2.2;
}

/*
@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:85%;/*横半分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;
}  
/*右エリア*/
/*
#container{
  width:75%;/*横半分50%にする*/
/*
}*/
}


/*右から画像が表示される*/
.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 =========== */




/* =========== 共通 =========== */
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;
}

.btn a,
.btn span {
  border: none;
  background-color: rgb(0 0 0 / 95%);
  color: #fff !important;
}
/* =========== 共通 =========== */




/* =========== ACCESS =========== */

.access_box{
  border: solid 1px #444;
  background-color: #fff;
  padding: 5%;
}
.access_text{
  font-weight: bold;
  font-size: 18px;
}

.access_icon{
  width: 80px !important;
  margin: 10px;
}


/* =========== ACCESS =========== */




/* 背景スクロール */
@keyframes infinity-scroll-left {
	from {
	  transform: translateX(0);
	}
	  to {
	  transform: translateX(-100%);
	}
	}
	.scroll-infinity {
		position: fixed;
		bottom: 20px;
	}
	.scroll-infinity__wrap {
	  display: flex;
	  overflow: hidden;
	}
	.scroll-infinity__list {
	  display: flex;
	  list-style: none;
	  padding: 0
	}
	.scroll-infinity__list--left {
	  animation: infinity-scroll-left 80s infinite linear 0.5s both;
	}
	.scroll-infinity__item {
	  width: 450px;
	  margin: auto 30px;
	}
	.scroll-infinity__item>img {
	  width: 100%;
	  /*border-radius: 15px;*/
      opacity: 1.0;
      filter: grayscale(100%);
	}

/* 768px */
@media only screen and (max-width: 48em) {
	.scroll-infinity {
		display: none;
	}
}


/* 影 */
.layer1 {
	/*border-radius: 15px;*/
	box-shadow: 0 0 5px gray;
  }
.layer2 {
	box-shadow: 15px 25px 25px rgba(0,0,0,.2);
  }

 /* 明朝 */
 .shippori-mincho {
	font-family: "Shippori Mincho", serif;
	/*font-weight: normal;*/
	font-style: normal;
  } 
/* 英字 */
.sulphur-point {
	font-family: "Sulphur Point", sans-serif;
	font-weight: 400;
	font-style: normal;
  }


.bg_image_box{
  position: fixed;
  top: 50px;
  left: 120px;
  width: 200px;
}
/* 1200px */
@media only screen and (max-width: 75em) {
.bg_image_box{
		position: fixed;
		top: 150px;
		left: 50px;
		width: 120px;
	  }
	}
/* 768px */
@media only screen and (max-width: 48em) {
.bg_image_box{
		display: none;
	  }
	}

