@charset "UTF-8";

/*タブ切り替え全体のスタイル*/
.tabs {
  padding-bottom: 40px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  max-width: 1100px;
  margin: 60px auto;
}

/*タブのスタイル*/
.tab_item {
  width: calc(100%/3);
  height: auto;
  border-bottom: 3px solid #5ab4bd;
  background-color: #d9d9d9;
  line-height: 50px;
  font-size: 16px;
  text-align: center;
  color: #565656;
  display: block;
  float: left;
  font-weight: bold;
  transition: all 0.2s ease;
}
.tab_item:hover {
  opacity: 0.75;
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
  display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab_content {
	display: none;
	padding: 40px 40px 0;
	clear: both;
	overflow: hidden;
	font-size: 1.5rem;
}

/*選択されているタブのコンテンツのみを表示*/
#aa:checked ~ #aa_content,
#bb:checked ~ #bb_content,
#cc:checked ~ #cc_content,
#dd:checked ~ #dd_content{
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
  background-color: #5ab4bd;
  color: #fff;
}

.wedding-nav-content {
    max-width: 700px;
	margin: 0 auto;
    padding: 0 4%;
	top: 0vh;
	left: 0;
}

/*スクロールダウン全体の場所*/
.scroll {
	cursor: pointer;
}
.scrolldown1{
    /*描画位置※位置は適宜調整してください*/
	position:absolute;
	left:15%;
	bottom: 5vh;
    /*全体の高さ*/
	height:50px;
}

/*Scrollテキストの描写*/
.scrolldown1 span{
    /*描画位置*/
	position: absolute;
	left:-15px;
	top: -15px;
    /*テキストの形状*/
	color: #000000;
	font-size: 0.7rem;
	letter-spacing: 0.05em;
}

/* 線の描写 */
.scrolldown1::after{
	content: "";
    /*描画位置*/
	position: absolute;
	top: 0;
    /*線の形状*/
	width: 1px;
	height: 30px;
	background: #000000;
    /*線の動き1.4秒かけて動く。永遠にループ*/
	animation: pathmove 1.4s ease-in-out infinite;
	opacity:0;
}

/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	30%{
		height:30px;
		opacity: 1;
	}
	100%{
		height:0;
		top:50px;
		opacity: 0;
	}
}

	.logo1 {
		width: 50%;
	}
	.logo {
		width: 120px;
	}
	.page-header-1 {
		/*height: 100px;*/
		height: 50px;
	}
	.main-nav-1 {
		margin-top: 0;
		list-style: none;
	}
	.main-concept {
		margin: 50px 5% 0;
		font-size: 1rem;
		line-height: 25px;
	}
	.main-concept h2 {
		font-size: 1.25em;
	}
	.scrolldown1 {
		left: 50%;
		bottom: 20vh;
	}
}
.wrapper {
    max-width: 1300px;
/*    margin: 5% auto 0;*/
    padding: 0 4%;
}
.order-nav{
	margin-top: 10vh;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
}
.order-nav span {
	font-size: 1.2rem;
	color:#E77F00;
}
/*見出し*/
.caption {
    text-align: center;
	margin: 30px 0;
	font-family: 'Noto Serif JP', serif;
	font-size: 1.2rem;
	
}
.caption span{
     position: relative;
     display: inline-block;
     padding: 0 0.8em;
	 z-index: 2;
}
      
.caption span::before{
     position: absolute;
     content: '';
     top:0;
     right:0.2em;
     width: 0.2em;
     height:100%;
     border: solid 1px black;
     border-left: none;
}
 
.caption span::after{
     position: absolute;
     content: '';
     top:0;
     left:0;
     width: 0.2em;
     height:100%;
     border: solid 1px black;
     border-right: none;
}
/*ライン*/
.hr-text {
	line-height: 1em;
	margin: 5% 0;
	position: relative;
	outline: 0;
	border: 0;
	color: black;
	text-align: center;
	height: 1.5em;
	opacity: .5;
	z-index: 1;
}
.hr-text:before {
	content: '';
	background: -webkit-linear-gradient(left, transparent, #818078, transparent);
	background: linear-gradient(to right, transparent, #818078, transparent);
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	height: 1.5px;
	z-index: 1;
}
.hr-text:after {
	content: attr(data-content);
	position: relative;
	display: inline-block;
	color: black;
	padding: 0 .5em;
	line-height: 1.5em;
	background-color: #fcfcfa;
	z-index: 1;
}
/*ライン2*/
.hr-text1 {
	line-height: 1em;
	margin: 5% auto;
	position: relative;
	outline: 0;
	border: 0;
	color: white;
	text-align: center;
	height: 1.5em;
	opacity: .5;
	z-index: 1;
}
.hr-text1:before {
	content: '';
	background: -webkit-linear-gradient(left, transparent, #DDDBCE, transparent);
	background: linear-gradient(to right, transparent, #DDDBCE, transparent);
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	height: 1px;
	z-index: 1;
}
.hr-text1:after {
	content: attr(data-content);
	position: relative;
	display: inline-block;
	color: white;
	padding: 0 .5em;
	line-height: 1.5em;
	background-color: #fcfcfa;
	z-index: 1;
}

@media (max-width: 600px) {
	.caption {
		margin: 30px 0 0;
	}
	.hr-text1 {
		margin: 10% auto;
	}
	.tabs {
	  padding-bottom: 40px;
	  background-color: #fff;
	  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	  max-width: 1100px;
	  margin: 60px 3%;
	}
	.tab_item {
	  font-size: 0.9rem;
	}
	.tab_content {
		display: none;
		padding: 40px 10px 0;
		clear: both;
		overflow: hidden;
		font-size: 1.2rem;
	}
	.hr-text {
		line-height: 1em;
		margin: 15% 0 15%;
		position: relative;
		outline: 0;
		border: 0;
		color: black;
		text-align: center;
		height: 1.5em;
		opacity: .5;
		z-index: 1;
	}
}


/*共通ヘッダー・フッター用追加css*/
.menu {
	position: fixed;
	display: flex;
	left: 0;
	bottom: 0;
	background: rgba(255,255,255,0.8);
	width: 100%;
	padding: 0;
	z-index: 1000;
}
.menu li {
	display: table;
	table-layout: fixed;
	width: 100%;
	padding: 5px;
	list-style: none;
	text-align: center;
}
.menu a span {
	display: block;
	font-size: 8px;
}
.menu i img {
	width: 30px;
}

@media(min-width: 600px) {
	.bottom-menu {
		display: none;
		padding-top: 20px;
	}
}


footer ul h3 {
    display: block;
    position: relative;
	/*margin: 2% 2% 2% 4%;*/
    padding-left: 30px;
    font-weight: bold !important;
}
footer ul h3::before {
    content: '';
    height: 12px;
    width: 12px;
    display: block;
    background: #00a8ff;
    box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -webkit-box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -moz-box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    position: absolute;
    top: 0;
    left: 5px;
    transform: rotate(-50deg);
    -webkit-transform: rotate(-50deg);
    -moz-transform: rotate(-50deg);
    -o-transform: rotate(-50deg);
    -ms-transform: rotate(-50deg);
}
footer ul h3::after {
    content: '';
    height: 8px;
    width: 6px;
    display: block;
    background: #00a8ff;
    box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -webkit-box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    -moz-box-shadow: 0 0 5px rgba(255,255,255,.3) inset;
    position: absolute;
    top: 16px;
    left: 2px;
    transform: rotate(-90deg);
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    -ms-transform: rotate(-75deg);
}

@media (max-width: 600px) {
	footer {
		padding-bottom: 100px;
	}
}

/*ハンバーガーメニュー*/
.header-menu {
	position: fixed;
	top:0;
	width: 100vw;
	z-index: 100;
	background-color: rgba(255,255,255,0.35);
	-webkit-transition: 1.5s;
	-moz-transition: 1.5s;
	-o-transition: 1.5s;
	-ms-transition: 1.5s;
	transition: 1.5s;
}
.header-menu.change-color {
	background-color: rgba(255,255,255,1);
}
.hamburger-menu {
	display: none;
}

.more-btn {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 3%;
}
.more-btn a {
    display: inline-block;
    color: #4d4d4d;
    font-size: 15px;
    line-height: 1em;
    text-align: center;
    width: 90%;
    margin: 0 5%;
    max-width: 540px;
    height: 54px;
    padding-top: 20px;
    background-color: rgba(238,238,238,0.95);
    border-radius: 8px;
}
.menu-btn {
    position: fixed;
    top: 20px;
    right: 10px;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 90;	
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #3584bb;
    position: absolute;
	transition: all 0.2s;/*アニメーション設定*/
}
.menu-btn span:before {
    bottom: 8px;
}
.menu-btn span:after {
    top: 8px;
}
#menu-btn-check:checked ~ .menu-btn span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
}
#menu-btn-check {
    display: none;
}
#menu-btn-check:checked ~ .menu-content {
    left: 0;/*メニューを画面内へ*/
}
.menu-content {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 100px;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    background-color: #454545;
    transition: all 0.5s;/*アニメーション設定*/
}
.menu-content ul {
    padding: 50px 20px 0;
}
.menu-content ul li {
    border-bottom: solid 1px #9B9B9B;
    list-style: none;
}
.menu-content ul li a {
    display: block;
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
    color:#ffffff;
    text-decoration: none;
    padding: 15px 15px 5px;
    position: relative;
}
.menu-content ul li a::before {
    content: "";
    width: 7px;
    height: 7px;
    border-top: solid 2px #ffffff;
    border-right: solid 2px #ffffff;
    transform: rotate(45deg);
    position: absolute;
    right: 15px;
    top: 25px;
}
#pageTop {
  position: fixed;
  bottom: 110px;
  right: 20px;
}

html {
	scroll-behavior: smooth;
}

/*共通ヘッダー・フッター用追加css end*/
.flex {
	max-width: 1200px; 
	display: flex;
	justify-content: space-around;
	margin: 3% auto 0;
}
.flex-reverse {
	flex-direction: row-reverse;
}
.flex-slider {
	width: 50%;
	margin: 0 2.5%;
}
.flex-text {
	width: 45%;
	margin: 0 2% 0 5%;
}

@media (max-width: 600px) {
	.flex {
		max-width: 1200px; 
		display: block;
		margin: 3% auto 0;
	}
	.flex-slider {
		width: 95%;
		margin: 0 2.5%;
	}
	.flex-text {
		width: 95%;
		margin: 0 2.5%;
	}
}

/*フェードアニメーション*/
/* 画面外にいる状態 */
.fadein_bottom {
	opacity : 0;
	transform : translate(0, 100px);
	transition : all 1.0s;
}
.fadein_right {
	opacity : 0;
	transform : translate(-200px, 0);
	transition : all 1.5s;
}
.fadein_top {
	opacity : 0;
	transform : translate(-200px, 0);
	transition : all 1.5s;
}

/* 画面内に入った状態 */
.fadein_bottom.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}
.fadein_right.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}
.fadein_top {
	opacity : 1;
	transform : translate(0, 0);
}

.doga {
	margin: 0 auto;
	max-width: 600px; 
}