@charset "UTF-8";

body {
	width: 100vw;
	min-height: 100vh;
	margin: 0;
	padding: 0;
	font-family: 'Outfit','Noto Sans JP',"Montserrat", "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-size: 3.75vw;
	font-weight: 400;
	line-height: 2;
	color: #aa965c;
	background: #fff;
	overflow-x: hidden;
	display:-ms-flexbox;
	display:flex;
	-ms-flex-direction: column;
	flex-direction: column;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
div.inner {
	width: 100vw;
	height: auto;
	min-height: 100vh;
	overflow: hidden;
	position: relative;
}
main, section, footer {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
}
div {
	margin: 0;
	padding: 0;
}
a:hover {
	opacity: 0.85;
}
a,a:link,a:hover,a:visited{
text-decoration:none;
}
ol,
ul {
	list-style: none;
	padding-inline-start: 0;
	margin: 0;
	margin-block-start: 0;
	margin-block-end: 0;
	margin-inline-start: 0;
	margin-inline-end: 0;
}
.section_inner, .footer_inner {
	width: 90%;
	margin: 10vw auto;
}
p {
	text-align: justify;
}
.small {
	font-size: 0.7em;
}
.fa, .fas, .far, .fal, .fad, .fab {
	font-family: 'Font Awesome 5';
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	line-height: 1;
}


/*----------------------------------------------- 共通 */
.inner {
	width: 100vw;
	height: 100vh;
	background-image: url(../img/back.svg);
	background-repeat: repeat;
	background-size: 30px;
	border-top: solid 1.5em #dfe200;
	border-bottom: solid 1.5em #dfe200;
	position: relative;
	padding-bottom: 3em;
}
.inner::before {
	content: '';
	width: 100vw;
	height: 3em;
	background-image: url(../img/line_top.svg);
	background-repeat: repeat-x;
	background-size: 6em;
	display: block;
	position: absolute;
	top: 0;
	z-index: 1;
}
.inner::after {
	content: '';
	width: 100vw;
	height: 3em;
	background-image: url(../img/line_bottom.svg);
	background-repeat: repeat-x;
	background-size: 6em;
	background-position: bottom;
	display: block;
	position: absolute;
	bottom: 0;
	z-index: 1;
}
.btn {
	margin-top: 0.5em;
}
.btn a {
	position: relative;
	display:-ms-flexbox;
	display:flex;
	justify-content: space-around;
	align-items: center;
	margin: 0 auto;
	max-width: 205px;
	padding: 10px 0px 10px 25px;
	color: #aa965c;
	transition: 0.3s ease-in-out;
	font-weight: 500;
}
.btn a:before, .btn a:after {
	content: "";
	position: absolute;
	display: block;
	top: 50%;
}
.btn a:before {
	width: 0.5rem;
	height: 0.5rem;
	left: 0.65rem;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	z-index: 2;
	transform: translateY(-50%) rotate(45deg);
	transition: all 0.3s;
}
.btn a:after {
	left: 0;
	background: #dfe200;
	z-index: 1;
	width: 2rem;
	height: 2rem;
	border-radius: 4rem;
	transform: translateY(-50%);
	transition: all 0.5s;
}
.btn a span {
	position: relative;
	transition: all 0.3s;
	z-index: 3;
}
@media (hover: hover) {
	.btn a:hover span {
		color: #fff;
	}
	.btn a:hover:before {
		left: 2rem;
	}
	.btn a:hover:after {
		right: 0;
		width: 100%;
	}
}
@media (hover: none) {
	.btn a:active span {
		color: #fff;
	}
	.btn a:active:before {
		left: 2rem;
	}
	.btn a:active:after {
		right: 0;
		width: 100%;
	}
}

.p_bnr_w li {
	width: 80vw;
	max-width: 205px;
	margin: 20vw auto;
}
header {
	width: 100vw;
/*	height: 100vh;*/
	position: relative;
}
.header_inner {
	width: 100vw;
	margin-top: 3em;
/*	height: 100vh;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	overflow: hidden;*/
}
h1 {
	width: 80vw;
	max-width: 700px;
	margin: 5em auto 0;
}
.thank {
	margin: 1.5em auto 0;
	width: 35vw;
	max-width: 220px;
}
.couple {
	display:-ms-flexbox;
	display:flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin: 1.5em auto 0;
	width: 80vw;
	max-width: 500px;
}
.couple img {
	width: 30vw;
	max-width: 150px;
}
.couple p {
	width: 25vw;
	max-width: 100px;
	text-align: center;
	line-height: 1.5;
}
.nichiji {
	margin: 1em auto;
}
.nichiji p {
	line-height: 1.5;
	font-size: 0.8em;
	text-align: center;
}
.nichiji p:nth-of-type(2) {
	line-height: 1.5;
	font-size: 0.75em;
}
.cats {
	margin: 1.5em auto 0;
	width: 18vw;
	max-width: 100px;
}
.ft_message {
	max-width: 350px;
	margin: auto;
}
.ft_message p {
	font-size: 0.75em;
	font-weight: 200;
	text-align: center;
}

.not_front .header_inner .ebi a {
	height: 100%;
	width: 100%;
	display: block;
}
.not_front .header_inner .ebi {
	width: 15vw;
	height: 15vw;
	background-image: url(../img/go_top.svg);
	background-repeat: no-repeat;
	margin: 4em auto 0 1em;
}
@media (hover: hover) {
	.not_front .header_inner .ebi:hover {
		background-image: url(../img/go_top_h.svg);
		transition: all 0.3s ease 0s;
	}
}
@media (hover: none) {
	.not_front .header_inner .ebi:active {
		background-image: url(../img/go_top_h.svg);
	}
}

.go_top {
	text-align: center;
}
.go_top a {
	font-weight: 500;
	color: #aa965c;
}
.go_top i {
	font-size: 1.2em;
	margin-right: 5px;
}
.keiba {
	margin: 20vw auto;
}
.keiba_img {
	width: 70vw;
	max-width: 220px;
	margin: auto;
}
.btn_bk {
	margin-top: 0.5em;
}
.btn_bk a {
	position: relative;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin: 0 auto;
	max-width: 240px;
	padding: 10px 25px;
	color: #fff;
	transition: 0.3s ease-in-out;
	font-weight: 600;
	background: #aa965c;
	z-index: 0;
}
.btn_bk a:before, .btn_bk2 a:after {
	content: "";
	position: absolute;
	display: block;
	transition: all 0.3s;
}
.btn_bk a:before {
	opacity: 0;
	width: 7px;
	height: 7px;
	top: 50%;
	right: 1.4rem;
	border-top: solid 2px #FFF;
	border-right: solid 2px #FFF;
	transform: translateY(-50%) rotate(45deg);
}
.btn_bk a:after {
	opacity: 0;
	right: -2px;
	bottom: -2px;
	z-index: -1;
	width: 0;
	height: 0;
}
.btn_bk a:hover {
	padding: 10px 25px 10px 10px;
	color: #fff;
	background: #dfe200;
	opacity: 1;
}
.btn_bk a:hover:before {
	opacity: 1;
	border-color: #fff;
}
.btn_bk a:hover:after {
	opacity: 1;
	width: calc(100% + 2px);
	height: calc(100% + 2px);
}
.go_back a {
	color: #aa965c;
}
.go_back a i {
	margin-right: 5px;
}

.back_imgs {
	position: fixed;
	width: 40vw;
	height: 45vw;
}
.back_imgs.back_imgs_r01 {
	right: 0;
	top: 20vh;
}
img.r01_cl_01 {
	width: 30vw;
	right: -3vw;
	top: 0;
	position: absolute;
}
img.r01_cl_02 {
	width: 25vw;
	top: 13vw;
	right: -8vw;
	position: absolute;
}
img.r01_fl_01 {
	width: 16vw;
	top: -11vw;
	right: -4vw;
	position: absolute;
}
img.r01_fl_02 {
	width: 12vw;
	top: 19vw;
	right: 9vw;
	position: absolute;
}
.back_imgs.back_imgs_r02 {
	right: 0;
	bottom: 15vh;
}
img.r02_cl_01 {
	width: 28vw;
	right: 3vw;
	top: 5vw;
	position: absolute;
}
img.r02_cl_02 {
	width: 25vw;
	top: 13vw;
	right: -8vw;
	position: absolute;
}
img.r02_fl_01 {
	width: 11vw;
	top: -11vw;
	right: -4vw;
	position: absolute;
}
img.r02_fl_02 {
	width: 12vw;
	top: -4vw;
	right: 2vw;
	position: absolute;
}
img.r02_fl_03 {
	width: 12vw;
	top: 19vw;
	right: 9vw;
	position: absolute;
}
.back_imgs.back_imgs_l01 {
	left: 0;
	top: 27vh;
}
img.l01_cl_01 {
	width: 30vw;
	left: 1vw;
	top: 0;
	position: absolute;
}
img.l01_cl_02 {
	width: 25vw;
	top: 5vw;
	left: -8vw;
	position: absolute;
}
img.l01_fl_01 {
	width: 11vw;
	top: 13vw;
	right: 18vw;
	position: absolute;
}
img.l01_fl_02 {
	width: 15vw;
	top: 26vw;
	left: 2vw;
	position: absolute;
}
.back_imgs.back_imgs_l02 {
	left: 0;
	bottom: 3vh;
}
img.l02_cl_01 {
	width: 30vw;
	left: 1vw;
	top: 6vw;
	position: absolute;
}
img.l02_fl_01 {
	width: 10vw;
	top: -10vw;
	right: 18vw;
	position: absolute;
}
img.l02_fl_02 {
	width: 15vw;
	top: -5vw;
	left: -5vw;
	position: absolute;
}
img.l02_fl_03 {
	width: 11vw;
	top: 16vw;
	right: 9vw;
	position: absolute;
}
img.l02_fl_04 {
	width: 9vw;
	top: 23vw;
	right: 17vw;
	position: absolute;
}

.fuwafuwa_01 {
	animation: fuwafuwa infinite ease-in-out alternate;
	animation-duration: 2.5s;
}
.fuwafuwa_02 {
	animation: fuwafuwa infinite ease-in-out alternate;
	animation-duration: 3.5s;
}
.fuwafuwa_03 {
	animation: fuwafuwa infinite ease-in-out alternate;
	animation-duration: 2.85s;
}
@keyframes fuwafuwa {
	0% {
		transform:translate(0, 0) rotate(-7deg);
	}
	50% {
		transform:translate(0, -7px) rotate(0deg);
	}
	100% {
		transform:translate(0, 0) rotate(7deg);
	}
}

.yura_01 {
	animation: yura infinite ease-in-out alternate;
	animation-duration: 5s;
}
.yura_02 {
	animation: yura infinite ease-in-out alternate;
	animation-duration: 4s;
}
.yura_03 {
	animation: yura infinite ease-in-out alternate;
	animation-duration: 6s;
}
@keyframes yura {
	0% {
		transform:translate(0, 0);
	}
	50% {
		transform:translate(15px, 0);
	}
	100% {
		transform:translate(0, 0);
	}
}


@keyframes infinity-scroll-left {
	from {
		transform: translateX(0);
	}
	to {
	transform: translateX(-100%);
	}
}
/*IE11対策
----------------------------*/
_:-ms-lang(x)::-ms-backdrop,
.top_img {
	display: -ms-grid;
	overflow: hidden;
}
/*----------------------------*/
.top_img {
	margin-top: 10vw;
}
.top_img_wrap {
	display: flex;
	overflow: hidden;
}

.top_img_list {
	display: flex;
	list-style: none;
}
.top_img_list_left{
animation :infinity-scroll-left 150s infinite linear 0.5s both;
}

.top_img_item {
	height: calc(100vw / 3);
}
.top_img_item > img{
	width: auto;
	height: 100%;
}


/*----------------------------------------------- 詳細ページ */
.detail .section_inner {
	margin-top: 2vw;
}
.dtl_bnr {
	width: 80vw;
	max-width: 205px;
	height: 10vw;
	background-repeat: no-repeat;
	margin: 0 auto 5vw;
}
.hoshino .dtl_bnr {
	background-image: url(../img/couple.svg);
	height: 15vw;
	max-width: 100px;
}
.tbl_1 .dtl_bnr {
	background-image: url(../img/tbl_1.svg);
}
.tbl_2 .dtl_bnr {
	background-image: url(../img/tbl_2.svg);
}
.tbl_3 .dtl_bnr {
	background-image: url(../img/tbl_3.svg);
}
.tbl_4 .dtl_bnr {
	background-image: url(../img/tbl_4.svg);
}
.tbl_5 .dtl_bnr {
	background-image: url(../img/tbl_5.svg);
}
.tbl_6 .dtl_bnr {
	background-image: url(../img/tbl_6.svg);
}
.tbl_7 .dtl_bnr {
	background-image: url(../img/tbl_7.svg);
}
.tbl_8 .dtl_bnr {
	background-image: url(../img/tbl_8.svg);
}
.tbl_9 .dtl_bnr {
	background-image: url(../img/tbl_9.svg);
}
.tbl_10 .dtl_bnr {
	background-image: url(../img/tbl_10.svg);
}
.tbl_11 .dtl_bnr {
	background-image: url(../img/tbl_11.svg);
}
.detail h2 {
	font-weight: 600;
	line-height: 1.5;
	font-size: 1.25em;
	text-align: center;
	margin: 5vw auto;
}
.dtl_cmnt {
	margin: 5vw auto;
	border-top: dashed 1px #333;
	padding-top: 5vw;
}
.secretariat {
	margin: 2em auto 3em;
}
.detail .go_top {
	margin: 5em auto;
}
.detail input {
	background-color: #fff;
	margin: 5px 10px 5px 5px;
	border: solid 1px #aa965c;
	padding: 3px 5px;
}
.detail input[type="submit"] {
	background-color: #aa965c;
	border: solid 1px #aa965c;
	color: #fff;
	padding: 3px 20px;
	margin: 5px auto;
}
.dtl_cnt form p:last-of-type {
	text-align: center;
	margin: auto;
}
.dtl_cnt p {
	text-align: center;
}
.secretariat p {
	font-size: 0.85em;
}
.secretariat p.ft_cont_link {
	font-size: 1em;
}
#imagelightbox {
	position: fixed;
	z-index: 9999;
	-ms-touch-action: none;
	touch-action: none;
}
.detail .memo {
	text-align: center;
	margin-bottom: 1em;
	font-size: 0.9em;
}


/*----------------------------------------------- footer */
footer .section_inner {
	margin-bottom: 0;
}
.copy small::before {
	content: '\f1f9';
	font-family: "Font Awesome 5 Free";
	font-size: 0.85em;
	font-weight: 400;
	margin-right: 5px;
}
.copy {
	text-align: center;
	margin-bottom: 10px;
}
.ft_logo {
	width: 10vw;
	margin: auto;
}
.ft_name {
	width:30vw;
	margin: 2vw auto;
}
.ft_logo img,
.ft_name img {
	width: 100%
}
.ft_cont_link {
	text-align: center;
	margin: 2vw auto;
}
.ft_cont_link:first-of-type{
	margin-top: 4vw;
}
.ft_cont_link a {
	color: #aa965c;
}
.ft_cont_link i {
	margin-right: 5px;
}
p.privacy {
	text-align: center;
	margin: 1em auto 0.5em;
}
p.privacy a {
	color: #aa965c;
	font-size: 0.85em;
	font-weight: 500;
}


/*CSSアニメーション*/
@keyframes blink{
	0% {opacity:0;}
	100% {opacity:1;}
}
.blinking{
	animation:blink 2s ease-in-out infinite alternate;
}
@keyframes blinkslow{
	0% {opacity:0;}
	20%{opacity:1;}
	100% {opacity:1;}
}
.blinking_slow{
	animation:blinkslow 4s ease-in-out infinite alternate;
}


@keyframes yurayura {
	0% , 100%{
	transform: rotate(10deg);
}
	50%{
	transform: rotate(-10deg);
	}
}
.yurayura{
	transform-origin: center bottom;
	animation: yurayura 2s linear infinite;
}

@keyframes purupuru {
	0% {	transform: translate(0, 0);}
	5% {	transform: translate(-5px, -0);}
	10% {	transform: translate(5px, 0);}
	15% {	transform: translate(-5px, -0);}
	20% {	transform: translate(5px, 0);}
	25% {	transform: translate(-5px, -0);}
	30% {	transform: translate(0, 0);}
	100% {	transform: translate(0, 0);}
}
.purupuru {
	animation: purupuru 1s infinite alternate;
}

@keyframes katakata {
	0% {transform:translate(0, 0) rotate(0deg);}
	21% {transform:translate(0, 0) rotate(0deg);}
	22% {transform:translate(0, 0) rotate(-3deg);}
	23% {transform:translate(0, -1px) rotate(0deg);}
	24% {transform:translate(0, -1px) rotate(3deg);}
	25% {transform:translate(1px, 0) rotate(-2deg);}
	26% {transform:translate(0, 1px) rotate(0deg);}
	27% {transform:translate(0, 0) rotate(3deg);}
	28% {transform:translate(0, 0) rotate(0deg);}
	100% {transform:translate(0, 0) rotate(0deg);}
}
.katakata {
	animation:katakata 4s infinite ease-in-out alternate;
}

@keyframes gradationTextAnimation{
	0%{
		background-position: 0 0;
	}
	50%{
		background-position: 100% 0;
	}
	100%{
		background-position: 0 0;
	}
}

@keyframes fadein{
	from{
		opacity: 0;
		transform: translatey(20px);
	}
	to{
	opacity: 1;
	transform: translatey(0);
	}
}

/*========= ローディング画面のためのCSS ===============*/
#splash {
	position: fixed;
	width: 100%;
	height: 100%;
	background: #F7C3C0;
	z-index: 9999999;
	text-align:center;
	color:#fff;
}
/*========= 画面遷移のためのCSS ===============*/
.splashbg{
	display: none;
}
body.appear .splashbg{
	display: block;
	display: none;
	content: "";
	position:fixed;
	z-index: 999;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
	transform: scaleX(0);
	background-color: #FC7CA4;/*伸びる背景色の設定*/
	animation-name:PageAnime;
	animation-duration:0.5s;
	animation-timing-function:ease-in-out;
	animation-fill-mode:forwards;
}

@keyframes PageAnime{
	0% {
		transform-origin:right;
		transform:scaleX(0);
	}
	50% {
		transform-origin:right;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:left;
	}
	100% {
		transform-origin:left;
		transform:scaleX(0);
	}
}

#container{
	opacity: 0;
}
body.appear #container{
	animation-name:PageAnimeAppear;
	animation-duration:0.5s;
	animation-delay: 0.5s;
	animation-fill-mode:forwards;
	opacity: 0;
}

@keyframes PageAnimeAppear{
	0% {
		opacity: 0;
		}
		100% {
		opacity: 1;
	}
}


.detail .foogallery.fg-dark .fg-item-inner {
	border: none;
	background-color: none;
}


/*----------------------------------------------- 固定ページ */
.fix_page {
	padding-top: 15vw;
}
.fix_page h2 {
	font-size: 11vw;
	font-weight: 600;
}

/*----------------------------------------------- 404 */
.txt_404 p {
	text-align: center;
	margin: 3em auto;
}
.fix_page.page_404 h2 {
	font-size: 11vw;
	text-align: center;
	color: #b3b3b3;
}
.img_404 {
	width: 70vw;
	max-width: 350px;
	display: block;
	margin: 2em auto 3em;
}


/*----------------------------------------------- privacy-policy */
.privacy-policy h2 {
	font-weight: 100;
	font-size: 6vw;
	margin-bottom: 1.25em;
}
.privacy-policy p {
	font-size: 0.9em;
}
.privacy-policy > div >div {
	margin: 8.5vw auto;
}
.privacy-policy h4 {
	font-weight: 600;
	color: #aa965c;
	margin-bottom: 0.5em;
}
.privacy-policy hr {
	margin: 3em auto;
}
.privacy-policy p.go_top {
	margin: 5em auto;
}
.privacy-policy p a {
	color: #aa965c;
}
.privacy-policy p a i {
	margin-right: 5px;
}






















