@charset "utf-8";
/* CSS Document */
@font-face {
    font-family: 'damionregular';
    src: url('../font/damion-regular-webfont.woff2') format('woff2'), url('../font/damion-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
#hotel:root {
    --color-key: #FBBF24;
}
#funeral:root {
    --color-key: #C4CDF9;
}
html, body {
    height: 100%;
}
body {
    color: var(--color-main);
    margin: 0 auto;
}
.gfont {
    font-family: 'Amatic SC', cursive;
    font-weight: 300;
}
.gfont2 {
    font-family: 'Niconne', cursive;
    font-weight: normal !important;
}
#billboard {
    z-index: 1;
}
.sp-indention {
    display: none;
}
@media (max-width: 768px) {
    .sp-indention {
        display: inherit;
    }
}

/* ==============================================================
   #見出し
   ============================================================== */
.sec-ttl {
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    margin-top: 0;
    margin-bottom: 32px;
}
.sec-ttl .ttl-txt {
    border-bottom: var(--color-main) solid 1px;
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1.6;
    display: inline-block;
    margin: 0 auto;
    padding: 0 1em;
}
.sec-ttl .ttl-txt::before, .sec-ttl .ttl-txt::after {
    content: "";
    border: var(--color-main) solid 1px;
    height: 7px;
    width: 7px;
    transform: rotate(45deg);
    margin: auto;
    position: absolute;
    bottom: -4px;
}
.sec-ttl .ttl-txt::before {
    left: -14px;
}
.sec-ttl .ttl-txt::after {
    right: -14px;
}
.sec-ttl .translated-txt {
    font-size: 1.6rem;
    font-weight: 600;
    display: block;
    letter-spacing: .1em;
    padding-left: .1em;
    margin-top: 1em;
}
@media (min-width: 768px) {
    .sec-ttl .ttl-txt {
        font-size: 6.4rem;
        line-height: 1.4;
    }
    .sec-ttl .translated-txt {
        font-size: 1.8rem;
        letter-spacing: .2em;
        padding-left: .2em;
    }
}
.lead-ttl {
    color: var(--color-key);
    font-size: 2rem;
    font-weight: bold;
    margin-top: 0;
    margin-bottom: 3.2rem;
}
@media (min-width: 768px) {
    .lead-ttl {
        font-size: 2.4rem;
        letter-spacing: .1em;
        padding-left: .1em;
        margin-bottom: 6.4rem;
    }
}
.lead-txt {
    font-size: 1.4rem;
    text-align: center;
    line-height: 1.8;
    margin-bottom: 3.2rem;
}
@media (min-width: 768px) {
    .lead-txt {
        font-size: 1.6rem;
        margin-bottom: 6.4rem;
    }
    .lead-ttl + .lead-txt {
        margin-top: -3.2rem;
    }
}


/* ==============================================================
   #レイアウト
   ============================================================== */
#main {
    z-index: 2;
}
.section {
    margin: 96px 0;
}
@media (min-width: 1280px) {
    #main {
        padding-left: var(--gutter-left);
        padding-right: var(--gutter-right);
        z-index: 2;
    }
    .section {
        margin: 240px 0;
    }
}
/* ==============================================================
   #header
   ============================================================== */
#header {
    display: flex;
    align-items: center;
    height: var(--header);
    padding-left: 4vw;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 10;
}
#header.isactive {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    transform: translate3d(0, 0, 0);
}
#logo a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
#logo #wish-logo {
    fill: #A08358;
    height: 18px;
}
@media (min-width: 1280px) {
    #header {
        height: 80px;
        padding-left: 24px;
    }
    #logo {}
    #logo a {
        display: flex;
    }
    #logo #wish-logo {
        height: 24px;
        width: auto;
    }
}
/* ==============================================================
   #キービジュアル
   ============================================================== */
#billboard {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100vh;
    width: 100%;
    overflow: hidden;
    z-index: 3;
}
#catchphrase {
    /*background-color: rgba(0,0,0,0.15);*/
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: auto;
    opacity: 0;
    filter: blur(64px);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 10;
    transition: opacity ease-out .8s, filter ease-out .8s;
    transition-delay: .4s;
}
#catchphrase.actvie {
    opacity: 1;
    filter: blur(0px);
}
#catchphrase svg {
    display: block;
    fill: var(--color-main);
    height: auto;
    width: 100%;
    max-width: 75%;
}
@media (min-width: 1280px) {
    #billboard {
        height: calc(100vh);
    }
    #catchphrase svg {
        max-width: 50%;
    }
}
/* ==============================================================
   #ビルボード：スライドショー
   ============================================================== */
#billboard #billboard-slider {
    width: 100% !important;
    height: 100% !important;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}


/* ==============================================================
   #サポート制度
   ============================================================== */
.support-item {
    margin-top: 60px;
}
.support-item a {
    display: block;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.support-item img {
    border-radius: 6px;
}
.support-item h3 {
    color: #A08358;
    font-weight: bold;
    font-size: 1.8rem;
    margin-top: 20px;
}
.support-item p {
    text-align: center;
}
@media (min-width: 1280px) {
    .support-item {
        margin-top: 0;
    }
    .support-item p {
        font-size: 1.4rem;
    }
}
/* ==============================================================
   #サポート制度
   ============================================================== */
.oc-btn-area {
    background-image: url(../img/demo_1.jpg);
    background-size: cover;
    background-position: center;
    height: 100vh;
}
#contact-info {
    background-color: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    height: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
#contact-info a {
    font-weight: 700;
    font-size: 1.6rem;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
}
#contact-info .contact-btn {
    background-color: #FFF;
    border-radius: 6px;
    height: 140px;
    margin-top: 20px;
    box-shadow: rgba(0, 0, 0, 0.25) 0 10px 32px;
    transition: background-color ease-out .2s, box-shadow ease-out .2s;
}
#contact-info [class*="fw-col-"]:nth-of-type(1) .contact-btn {
    margin-top: 0;
}
#contact-info .contact-btn::before {
    content: "";
    border: #A08358 solid 1px;
    margin: auto;
    position: absolute;
    top: 8px;
    right: 8px;
    bottom: 8px;
    left: 8px;
    opacity: 0.5;
}
#contact-info .contact-btn:hover {
    box-shadow: rgba(0, 0, 0, 0.5) 0 0 0;
}
.contact-btn span {
    display: block;
    font-size: 2.4rem;
    font-family: "Times New Roman", Times, serif;
    letter-spacing: .1em;
    padding-left: .1em;
    line-height: 1;
}
.contact-btn span.gfont-b {
    font-size: 2.8rem;
    font-weight: normal;
    letter-spacing: 0;
    padding-left: 0;
}
.contact-btn small {
    border-bottom: #A08358 solid 1px;
    color: #A08358;
    display: block;
    font-weight: bold;
    font-size: 1.4rem;
    line-height: 1.4;
    margin-bottom: 15px;
}
.contact-btn .arrow {
    background-color: #A08358;
    border-radius: 100%;
    display: block;
    height: 32px;
    width: 32px;
    margin: auto;
    position: absolute;
    top: 0;
    right: 16px;
    bottom: 0;
}
.contact-btn .arrow::before {
    content: "";
    border-top: #FFF solid 1px;
    border-left: #FFF solid 1px;
    width: 8px;
    height: 8px;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 5px;
    bottom: 0;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}
#contact-1 .contact-btn {
    background-color: #FFF1EC;
    background-image: url(../img/img_opencampus_lage.png);
    background-position: left bottom;
    background-size: auto 90%;
}
#contact-1:hover .contact-btn {
    background-color: #FFD7CA;
}
#contact-2 .contact-btn {
    background-color: aliceblue;
    background-image: url(../img/bg_btn_02.png);
    background-position: bottom right;
    background-size: auto 100%;
}
#contact-2:hover .contact-btn {
    background-color: #D5EAFF;
}
#contact-3 .contact-btn {
    background-color: #FAF9E8;
}
#contact-3:hover .contact-btn {
    background-color: #F0EDC0;
}
@media (min-width: 1280px) {
    .oc-btn-area {
        height: auto;
    }
    .oc-btn-area {
        background-attachment: fixed;
    }
    #contact-info {
        display: block;
        padding-top: 80px;
        padding-bottom: 100px;
    }
    #contact-info .contact-btn {
        height: 160px;
    }
    #contact-info [class*="fw-col-"]:nth-of-type(1) .contact-btn {
        margin-top: 20px;
    }
    .contact-btn span {
        font-size: 3.2rem;
    }
    .contact-btn small {
        font-size: 1.6rem;
        font-weight: bold;
    }
    #contact-1 .contact-btn {
        background-position: 20px bottom;
        background-size: auto 90%;
    }
    #contact-3 {
        display: none;
    }
}
/* ==============================================================
   #ホスタピリティ
   ============================================================== */
.serif-wrap {
    height: 100vh;
    position: sticky;
    top: 0;
}
.serif-bg.se {
    background-image: url(../img/demo_5.jpg);
    background-size: cover;
    background-position: center;
    height: 100%;
    opacity: 0.14;
}
.serif {
    height: 33vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 8vw;
}
.serif p {
    font-family: "Times New Roman", Times, serif;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    line-height: 2.4;
}
.serif span {
    display: inline-block;
}
.bokeh-fade {
    filter: blur(24px);
    transform: translate3d(0, 64px, 0);
    -webkit-transform: translate3d(0, 64px, 0);
    transition: filter ease-out .5s, transform ease-out .5s;
}
.bokeh-fade.fade-active {
    filter: blur(0);
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
}
@media (min-width: 1280px) {
    .serif-wrap {
        padding-top: calc(var(--gutter-right) * 1);
        padding-bottom: calc(var(--gutter-right) * 1);
    }
    .serif-bg {}
    .serif {
        height: 50vh;
    }
    .serif p {
        font-size: 2.4rem;
    }
}
/* ==============================================================
   #ソーシャル
   ============================================================== */
#sns-area {
    background-color: var(--color-thin);
    padding-top: 60px;
}
#sns-ttl {
    text-align: center;
    font-size: 1.6rem;
    margin-top: 0;
    margin-bottom: 30px;
}
#sns-ttl span {
    transform: skew(-12deg) rotate(-4deg);
    display: inline-block;
    max-width: 70%;
    margin: auto;
}
#sns-ttl span::before, #sns-ttl span::after {
    content: "";
    border-left: var(--color-mens) solid 2px;
    width: 0;
    margin: auto;
    position: absolute;
    top: 0px;
    bottom: -5px;
}
#sns-ttl span::before {
    left: -2em;
    transform: skew(12deg) rotate(-24deg);
}
#sns-ttl span::after {
    right: -2em;
    transform: skew(12deg) rotate(24deg);
}
.links-sns {
    margin-bottom: 20px;
}
.links-sns-list {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
    margin: auto;
    padding-bottom: 60px;
    z-index: 7;
}
footer .links-sns-list {
    border-bottom: rgba(255, 255, 255, 0.3) solid 1px;
    padding-bottom: 20px;
    max-width: 100%;
}
.links-sns-list li {
    display: inline-block;
    position: relative;
    flex-basis: calc(100% / 5);
    text-align: center;
}
.links-sns-list li a {
    background-color: var(--color-main);
    border-radius: 50%;
    overflow: hidden;
    display: block;
    width: 48px;
    height: 48px;
    margin: auto;
}
.links-sns-list li a:hover {
    background-color: #FFB1B0;
}
footer .links-sns-list li a {
    background-color: #FFF;
    box-shadow: rgba(0, 0, 0, 0.5) 0 8px 16px -8px;
    width: 40px;
    height: 40px;
}
.links-sns-list li p {
    margin-bottom: 0;
    font-weight: bold;
}
.links-sns-list li svg {
    position: absolute;
    width: 14px;
    height: 14px;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}
.links-sns-list li.facebook svg {
    width: 8px;
    height: 14px;
}
.links-sns-list li.youtube svg {
    width: 18px;
    height: 14px;
}
.links-sns-list li.line svg {
    width: auto;
    height: 18px;
}
.links-sns-list a {
    display: block;
    width: 100%;
    height: 100%;
}
.links-sns-list a svg {
    fill: #FFF;
    display: block;
    position: absolute;
    transform: scale(1.5);
}
footer .links-sns-list a svg {
    fill: #A08358;
    transform: scale(1.2);
}
.links-sns-list a:hover svg {
    fill: #FFF;
}
footer .links-sns-list p {
    font-size: 1rem;
    margin: 10px auto 0;
}
@media (min-width: 1280px) {
    #sns-area {
        padding-top: 0;
        padding-bottom: 0;
    }
    #sns-ttl {
        font-size: 1.6rem;
    }
    #sns-ttl span {
        max-width: inherit;
    }
    #sns-ttl span::before, #sns-ttl span::after {
        top: -20px;
        bottom: -10px;
    }
    .links-sns-list {
        max-width: 40%;
    }
    footer .links-sns-list li a {
        width: 56px;
        height: 56px;
    }
    .links-sns-list a svg {
        transform: scale(1.75);
    }
    footer .links-sns-list p {
        font-size: 1.2rem;
    }
    footer .links-sns-list {
        border-bottom: none;
        padding-bottom: 0;
        max-width: 100%;
    }
}
/* ==============================================================
   #youtube動画
   ============================================================== */
#gmap.fw-youtube {
    position: relative;
    width: 100%;
    margin: auto;
    padding-top: 100vw;
    z-index: 10;
}
@media (min-width: 768px) {
    #gmap.fw-youtube {
        padding-top: 50vh;
    }
}
/* ==============================================================
   #コンバージョン
   ============================================================== */
#wish-conversion {
    background: linear-gradient(90deg, var(--color-key) 0%, #e4beed 100%);
    height: 56px;
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 900;
}
#wish-conversion a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}
#wish-conversion p {
    color: #FFF;
    font-weight: bold;
    line-height: 1.6;
    text-align: left;
}
#wish-conversion .img-oc {
    width: 72px;
    height: 72px;
    position: absolute;
    bottom: 0;
    left: 15px;
}
#wish-conversion .arrow {
    background-color: #FFF;
    border-radius: 100%;
    height: 40px;
    width: 40px;
    position: absolute;
    top: 8px;
    right: 8px;
}
#wish-conversion .arrow::before {
    content: "";
    border-top: var(--color-main) solid 2px;
    border-left: var(--color-main) solid 2px;
    width: 9px;
    height: 9px;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    margin: auto;
    position: absolute;
    top: 0;
    right: 3px;
    bottom: 0;
    left: 0;
}
@media (min-width: 768px) {
    #wish-conversion {
        border-radius: 100px;
        height: 80px;
        width: 400px;
        right: 15px;
        bottom: 15px;
        left: inherit;
    }
    #wish-conversion .arrow {
        top: 20px;
        right: 20px;
    }
}
/* ==============================================================
   #サイトマップメニュー
   ============================================================== */
#f-nav {
    display: none;
}
.g-nav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    flex-grow: 1;
}
.g-nav ul {
    font-size: 1.2rem;
    flex-basis: 50%;
    max-width: 50%;
    padding: 0 10px 0 15px;
}
.g-nav ul.home-item {
    flex-basis: 100%;
    max-width: 100%;
}
.nav-item-ttl {
    font-size: 1.4rem;
    font-weight: bold;
}
.nav-item > a {
    display: block;
    line-height: 1.4;
    padding: 6px 0 6px 15px;
}
.nav-item > a::before {
    content: "";
    background-color: rgba(255, 255, 255, 0.4);
    border-radius: 100%;
    border: none;
    height: 4px;
    width: 4px;
    margin: auto;
    position: absolute;
    top: 0;
    right: auto;
    bottom: 0;
    left: 2px;
}
@media (min-width: 1280px) {
    .g-nav ul {
        font-size: 1.2rem;
        flex-basis: 25%;
        max-width: 25%;
    }
    .g-nav ul.home-item {
        flex-basis: 25%;
        max-width: 25%;
    }
}
/* ==============================================================
   #フッターメニュー
   ============================================================== */
footer {
    background-color: #A08358;
    color: #FFF;
    z-index: 2;
    overflow: hidden;
}
#wish-info p {
    font-size: 1rem;
}
#footer-info {
    margin-top: 20px;
}
footer address {
    /*border-top: rgba(255, 255, 255, 0.3) solid 1px;*/
    font-size: 1.2rem;
    text-align: center;
    padding: 30px 0;
    margin: 20px auto 0;
}
footer address h4 {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
    margin: auto;
}
#f-logo {
    display: block;
    height: 24px;
    margin: auto auto 20px;
}
#f-logo svg {
    fill: #FFF;
    height: 100%;
    width: auto;
}
footer address h4 small {
    display: block;
    font-size: 1rem;
}
footer address p {
    font-size: 1.2rem;
    line-height: 1.4;
    text-align: center;
    margin: 10px 0 0;
}
footer address p span {
    font-size: 1.1rem;
    display: block;
    margin-top: 10px;
}
#copy {
    font-size: 1.2rem;
    text-align: center;
    padding: 64px 0 80px;
    margin: 0;
}
@media (min-width: 1280px) {
    #f-nav-wrap {
        border-left: rgba(255, 255, 255, 0.3) solid 1px;
    }
    #footer-info {
        margin-top: 60px;
    }
    #wish-info p {
        font-size: 1.3rem;
    }
    footer address {
        border-top: none;
        font-size: 1.2rem;
        text-align: left;
        padding: 0;
        margin: 0 0 30px;
    }
    #f-logo {
        height: 32px;
    }
    footer address p {
        font-size: 1.2rem;
        line-height: 1.4;
        margin: 30px 0 0;
    }
}
/* ==============================================================
   #フッター固定メニュー
   ============================================================== */
.marquee {
    display: flex;
    white-space: nowrap;
    width: 150px;
    overflow: hidden;
    margin-bottom: 3px;
}
.marquee small {
    color: #666;
    font-size: 10px;
    font-weight: normal;
    display: inline-block;
    padding: 0 1em;
    white-space: nowrap;
    animation-name: marquee;
    animation-timing-function: linear;
    animation-duration: 24s;
    animation-iteration-count: infinite;
}
.marquee small:after {
    content: "";
    white-space: nowrap;
}
@keyframes marquee {
    from {
        transform: translate(0%);
    }
    99%, to {
        transform: translate(-100%);
    }
}
#sticky-navi ul li:nth-child(1) a time {
    color: var(--color-main);
    display: flex;
    flex-direction: row;
    align-items: center;
    font-size: 14px;
    letter-spacing: 2px;
}
#sticky-navi ul li:nth-child(1) a time strong {
    letter-spacing: 0;
}
#sticky-navi ul li:nth-child(1) a time i {
    background-color: #A08358;
    border-radius: 100%;
    color: #FFF;
    display: inline-block;
    font-size: 10px;
    width: 20px;
    height: 20px;
    line-height: 20px;
    letter-spacing: 0;
    margin: 0 2px 0 0;
}
#sticky-navi ul li:nth-child(1) a img {
    width: auto;
    height: 60px;
    position: absolute;
    bottom: 0;
    right: -4px;
}
#sticky-navi ul li:nth-child(2) {
    background-color: #A08358;
    flex-basis: 20%;
    max-width: 20%;
    font-weight: bold;
}
#sticky-navi ul li:nth-child(3) {
    background-color: #00C300;
    flex-basis: 20%;
    max-width: 20%;
    font-weight: bold;
}
#sticky-navi ul li:nth-child(2) a img, #sticky-navi ul li:nth-child(3) a img {
    width: auto;
    height: 60px;
    margin: auto;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
}
.han {
    display: inline-block;
    transform: scaleX(.8);
    transform-origin: center;
    width: 150%;
}
/* ==============================================================
   #スクロールアイコン
   ============================================================== */
.icon-scroll {
    text-align: center;
    margin: auto;
    width: 64px;
    height: 100px;
    z-index: 100;
}
#billboard .icon-scroll {
    position: absolute;
    bottom: -50px;
    right: 0;
    left: 0;
}
#introduction .icon-scroll {
    height: 100px;
    margin: 0 auto;
    position: absolute;
    top: -50px;
    right: 0;
    left: 0;
    bottom: inherit;
}
.icon-scroll span {
    background-color: #000;
    margin: auto;
    height: 100px;
    width: 2px;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    animation: header-line 1.4s ease-out 0s infinite normal;
    z-index: 10;
}
#introduction .icon-scroll span {
    background-color: #000;
}
.icon-scroll i {
    background-color: #A08358;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #FFF;
    font-size: 2rem;
    font-family: serif;
    height: 40px;
    width: 40px;
    text-align: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: -6rem;
    bottom: 0;
    z-index: 2;
}
.icon-scroll i::before, .icon-scroll i::after {
    content: "";
    background-color: #A08358;
    border-radius: 100%;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transform-origin: center;
    animation: pulsate 2.4s ease-out;
    animation-iteration-count: infinite;
    z-index: -1;
}
.icon-scroll i::after {
    animation-delay: 3.6s;
}
/* ==============================================================
   #アニメーション
   ============================================================== */
.hov-action {
    overflow: hidden;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}
.hov-action:hover {
    animation-name: hov;
    animation-duration: .5s;
    animation-fill-mode: both;
}
@keyframes hov {
    0%, from {
        transform: none;
    }
    50% {
        transform: scale3D(0.92, 0.92, 1);
    }
    99.9%, to {
        transform: none;
    }
}
/* ==============================================================
   #ボタン
   ============================================================== */
.btn-wrap {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 0;
}
.fw-btn {
    background: #A08358;
    border-radius: 40px;
    box-shadow: 0px 16px 40px -16px rgba(0, 0, 0, 0.3);
    display: inline-flex;
    flex-direction: row;
    flex-grow: 1;
    align-items: center;
    justify-content: center;
    color: #FFF;
    font-size: 14px;
    font-weight: bold;
    line-height: 1.2;
    min-height: 56px;
    min-width: 75%;
    text-align: center;
    padding: 0 15px;
    cursor: pointer;
    transition: box-shadow ease-out .2s;
    margin: 0 auto;
}
.fw-btn:hover {
    color: #FFF;
    background-color: #FFB1B0;
    box-shadow: 0px 0px 0px -16px rgba(0, 0, 0, 8); /*animation: purupuru 0.4s 1;
	-webkit-animation: purupuru 0.4s 1;*/
}
.fw-btn.lage {
    width: 100%;
    max-width: inherit;
    padding: 20px 30px;
}
.btn-arrow {
    width: 20px;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 15px;
}
.btn-arrow::before {
    content: "";
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
}
.btn-arrow::before {
    content: "";
    border-top: #FFF solid 2px;
    border-left: #FFF solid 2px;
    width: 10px;
    height: 10px;
    margin: auto;
    position: absolute;
    right: 15px;
    transform: rotate(135deg);
}
.fw-btn .btn-arrow {
    border: rgba(255, 255, 255, 0.5) solid 2px;
    border-radius: 100%;
    height: 30px;
    width: 30px;
    display: inline-block;
    line-height: 20px;
    padding: 0;
    overflow: hidden;
}
.fw-btn .btn-arrow::before, .fw-btn .btn-arrow::after {
    content: "";
    border-style: solid;
    border-width: 4px 0 4px 6px;
    border-color: transparent transparent transparent #FFF;
    width: 0;
    height: 0;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    transition: ease-out .3s;
}
/* ==============================================================
   #トップ戻る
   ============================================================== */
.fw-page-top, .fw-page-bottom {
    position: fixed;
    margin: auto;
    right: 0;
    z-index: 300;
}
.fw-page-top {
    bottom: 0;
}
.fw-page-bottom {
    bottom: 0;
}
.fw-page-top a, .fw-page-bottom a {
    background-color: #A08358;
    display: block;
    width: 32px;
    height: 32px;
}
.fw-page-top a::before, .fw-page-bottom a::before {
    content: "";
    border-top: #FFF solid 2px;
    border-left: #FFF solid 2px;
    width: 10px;
    height: 10px;
    margin: auto;
    position: absolute;
}
.fw-page-top a::before {
    top: 5px;
    left: 0;
    right: 0;
    bottom: 0;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
}
.fw-page-bottom a::before {
    top: 0;
    left: 0;
    right: 0;
    bottom: 5px;
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
}
.fw-page-top a:hover::before {}
@media (min-width: 768px) {
    .fw-page-top a, .fw-page-bottom a {
        width: 56px;
        height: 56px;
    }
    .fw-page-top, .fw-page-bottom {
        right: 0;
    }
    .fw-page-top {
        bottom: 0;
    }
}
/* ==============================================================
   #アニメーション
   ============================================================== */
.anime-fade, .anime-fade-2 {
    opacity: 0;
    transform: translate3d(0, 32px, 0);
    -webkit-transform: translate3d(0, 32px, 0);
    transition: opacity ease-out .8s, transform ease-out .8s;
}
.anime-fade-2 {
    opacity: 0;
    transform: translate3d(0, 32px, 0);
    -webkit-transform: translate3d(0, 32px, 0);
    transition: opacity ease-out .8s, transform ease-out .8s;
}
.anime-fade.fade-active, .anime-fade-2.fade-active {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
}
.rellax {
    transition: transform ease-out .3s;
    will-change: transform;
}
@media (max-width: 1279px) {
    .rellax {
        transform: none !important;
    }
}