@charset "utf-8";

li{
	list-style-type: none
}
img{
	max-width: 100%;
	margin: 0 auto
}
div.row{
	max-width: 750px;
	margin: 0 auto
}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc {
    display: block !important
}
.sp {
    display: none !important
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */

@import url(https://fonts.googleapis.com/css?family=Lato:400,700);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
body {
    font-family: Lato, "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.8
}
#floating{
	position: fixed;
    bottom: 0;
    left: 0;
	background:rgb(0 0 0 / 50%) ;
    display: block;
	width: 100%;
	height: 120px;
    z-index: 50
}
.cv_area{
	position: relative;
	max-width: 750px;
	margin: 0 auto
}
.cv_area .cv_btn_area{
	position: absolute;
	bottom: 68px;
	left: 2vw
}
.cv_btn{
	margin: 25px auto 0;
    width: 650px;
    font-weight: 600;
    text-align: center;
    border-radius: 40px;
    box-sizing: border-box;
    box-shadow: 6px 6px 2px rgb(0 0 0 / 18%);
    background-image: linear-gradient(#06bcaf,#00c9cb,#00c9cb,#00c9cb,#06bcaf)
}
.cv_btn:hover{
	opacity: 0.8;
	transition: 0.7s
}
.cv_btn a{
	position: relative;
    font-weight: 600;
    font-size: 30px;
    padding: 7px 0 11px;
    display: block;
    z-index: 5;
    overflow: hidden;
    width: 100%;
    color: #fff;
    text-align: center;
    text-decoration: none;
    transition: .25s linear
}
.cv_btn a::before{
	content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: -800%;
    background-image: linear-gradient(130deg,rgba(255,255,255,0) 25%,rgba(255,255,255,0.8) 50%,rgba(255,255,255,0) 75%);
    -webkit-animation: shine 2.5s infinite;
    animation: shine 2.5s infinite
}
@-webkit-keyframes shine{100%{left:100%}}
@keyframes shine{100%{left:100%}}

.pageTop {
    position: fixed;
    bottom: 25px;
    right: 45px;
    display: none;
    z-index: 100;
    transform: rotate(-90deg)
}
.pageTop a {
    display: inline-block;
    border-radius: 15px;
    position: relative;
    background-image: linear-gradient(90deg,#06bcaf,#00c9cb,#00c9cb,#00c9cb,#06bcaf);
    width: 60px;
    height: 60px
}
.pageTop a:hover{
	opacity: 0.8;
	transition: 0.7s
}
.pageTop a:after {
    content: "";
    display: block;
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-60%,-50%) rotate(-45deg);
    width: 15px;
    height: 15px;
    border-right: 4px solid #fff;
    border-bottom: 4px solid #fff
}
.area{
	background: #e1f6ff;
	padding: 40px 20px 0
}
.area ul{
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 10px 0 50px 0
}
.area ul li{
	width: 226px;
    margin-top: 15px
}
.area ul li a:hover{
	opacity: 0.8;
	transition: 0.7s
}
.modal {
    display: none;
    position: fixed;
    top: 0;
    z-index: 1000
}
.modal__bg{
    background-color: rgba(0,0,0,.2)
}
.modal, .modal__bg {
    height: 100vh;
    width: 100%
}
.modal__bg, .modal__content {
    position: absolute
}
.modal__content {
    left: 50%;
    top: 44%;
    transform: translate(-50%,-50%);
    width: 450px;
    background: #fff;
    border-radius: 15px
}
.modal__content__body {
    height: 650px;
    overflow-y: scroll
}
.modal__content__inner {
    padding: 25px
}
.modal__content .area_map{
	min-height: 730px;
	position: relative
}
.modal__content .area_map .link--close{
	position: absolute;
    right: 18px;
    top: 8px;
    color: #fff;
    font-size: 2.4rem;
    font-weight: 700;
    cursor: pointer
}
.modal__content .area_map ul{
	display: flex;
    justify-content: space-between;
    margin: 0 20px;
    padding-top: 155px
}
.modal__content .area_map ul li{
	width: 162px
}
#modal-area-1 .modal__content .area_map{
	background: url(../images/ouen_explanation_map01.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-2 .modal__content .area_map{
	background: url(../images/ouen_explanation_map02.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-3 .modal__content .area_map{
	background: url(../images/ouen_explanation_map03.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-4 .modal__content .area_map{
	background: url(../images/ouen_explanation_map04.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-5 .modal__content .area_map{
	background: url(../images/ouen_explanation_map05.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-6 .modal__content .area_map{
	background: url(../images/ouen_explanation_map06.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-7 .modal__content .area_map{
	background: url(../images/ouen_explanation_map07.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-8 .modal__content .area_map{
	background: url(../images/ouen_explanation_map08.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-9 .modal__content .area_map{
	background: url(../images/ouen_explanation_map09.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-10 .modal__content .area_map{
	background: url(../images/ouen_explanation_map10.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-11 .modal__content .area_map{
	background: url(../images/ouen_explanation_map11.webp) no-repeat 0 0;
	background-size: 100%
}
#modal-area-12 .modal__content .area_map{
	background: url(../images/ouen_explanation_map12.webp) no-repeat 0 0;
	background-size: 100%
}
.modal__content .area_map .g_map{
	padding: 70px 15px 0
}
.modal__content .area_map .g_map iframe{
	width: 100%;
	height: 250px
}
#form_title{
	text-align: center
}
footer{
	margin: 30px 0 0;
    padding-bottom: 30px;
    text-align: center;
	font-size: 1.8rem;
    color: #744f4a;
    font-weight: 600
}
footer a {
    font-size: 1.8rem;
    color: #744f4a;
    font-weight: 600;
    text-decoration: none
}
footer a:hover {
    text-decoration: underline
}
.anniversary_thanks_content{
    max-width: 1050px;
    margin: 0 auto
}
.anniversary_thanks{
    position: relative
}
.anniversary_thanks ul{
    position: absolute;
    bottom: 100px;
    display: flex;
    justify-content: space-between;
    max-width: 100%;
    padding: 0 96px
}
.anniversary_thanks ul li:first-child{
    margin-right: 50px
}
@media screen and (min-width:768px) and ( max-width:1024px) {
.modal__content .area_map{
	min-height: 765px
}
a:hover,.cv_btn:hover,.pageTop a:hover{
	opacity: 1;
	transition: unset
}
}
@media screen and (min-width:768px) and ( max-width:900px) {
.pageTop{
	bottom:128px	
}
.anniversary_thanks ul{
    bottom: 85px
}
}
@media screen and (min-width:768px) and ( max-width:769px) {
.pageTop {
	right: 20px
}
.modal__content .area_map ul{
	padding-top: 175px
}
}

/* スマホ */
@media screen and (max-width: 767px) {
.pc {
    display: none !important
}
.sp {
    display: block !important
}
body {
    font-family: Lato, "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}
#floating{
	height: 70px
}
.cv_area .cv_btn_area{
	bottom: 10vw;
    left: 5vw
}
.cv_btn {
    margin: 3vw auto 0;
    width: 95vw;
	box-shadow: 4px 4px 2px rgb(0 0 0 / 18%)
}
a:hover,.cv_btn:hover,.pageTop a:hover{
	opacity: 1;
	transition: unset
}
.cv_btn a {
	padding: 7px 0;
    font-size: 17px
}
.pageTop {
    bottom: 75px;
    right: 10px
}
.pageTop a{
	width: 45px;
    height: 45px	
}
.area{
	padding: 20px 15px 0
}
.area ul{
	padding: 0 0 30px
}
.area ul li {
    width: 44.5vw;
    margin-top: 10px
}
.modal {
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1001
}
.modal__bg {
    background-color: rgba(0,0,0,.2)
}
.modal__content {
    background: #fff;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 95%;
    overflow-y: scroll;
	border-radius: 15px
}
.modal__content__body {
	height: auto
	}
.modal__content__inner {
    padding: 15px
}
.modal__content .area_map{
	min-height: 167vw
}
.modal__content .area_map ul {
	margin: 0 15px;
    padding-top: 36vw
}
.modal__content .area_map .g_map {
    padding: 16vw 15px 0
}
.modal__content .area_map .g_map iframe{
	height: 56vw
}
.modal__content .area_map ul li{
	width: 37vw	
}
.modal__content .area_map .link--close{
	right: 4vw;
    top: 1.4vw;
    font-size: 2.2rem
}
footer {
    margin: 30px 0 0;
    padding-bottom: 30px
}
.anniversary_thanks ul {
    display: block;
    justify-content: unset;
    bottom: 58px;
    padding: 0 50px
}
.anniversary_thanks ul li:first-child {
    margin: 0 0 25px 0
}
}
/* スマホ */