@charset "UTF-8";

/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

body {
    line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

nav ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}


/* ==============================
common
================================*/
html {
    scroll-behavior: smooth;
    font-size: 10px;
}

@media screen and (min-width:751px) {
    html {
        font-size: 14px;
    }
}

body {
    width: 100%;
    line-height: 1.6;
    color: #333;
}

main {
    max-width: 750px;
    margin: 0 auto;
    box-shadow: 0 0 12px rgb(0, 0, 0, 0.1);
}

img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
}

.inner {
    width: 90vw;
    margin: 0 auto;
}

@media screen and (min-width:751px) {
    .inner {
        width: 90%;
    }
}

/* ==============================
swiper
================================*/
.swiper-btn-relative {
    position: relative;
    overflow: hidden;
}

.swiper-preview-slides {
    width: 82vw;
    margin: 0 auto;
    padding-bottom: 30px;
}

.venue-slides img.swiper-slide,
.voice-slides img.swiper-slide,
.step-slides img.swiper-slide {
    width: 82vw;
    height: auto;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    color: #2c1e1e;
    font-size: 25px;
}

.gallery-showcase {
    position: relative;
    overflow: hidden;
}

.gallery-showcase .swiper-wrapper {
    transition-timing-function: linear;
}

.gallery-slide-img .swiper-slide {
    box-shadow: 0 0 5px rgb(0, 0, 0, 0.4);
}

.gallery-slide-img .swiper-slide .swiper-slide-img {
    /* width: 60vw !important; */
    height: auto;
    /* margin: 0 2.5vw; */
}


@media screen and (min-width:751px) {
    .swiper-preview-slides {
        width: 600px;
    }

    .venue-slides img.swiper-slide,
    .voice-slides img.swiper-slide,
    .step-slides img.swiper-slide {
        width: 60px;
        height: auto;
    }
}

/* ==============================
header
================================*/

/* header  */
#header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%;
}

header .header-inner {
    display: flex;
    justify-content: space-between;
    padding: 10px 2.5%;
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    align-items: center;
}

header .header-inner div:first-child {
    width: 35vw;
}

header .header-inner div.header-cta {
    width: 50vw;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}


@media screen and (min-width:751px) {
    header .header-inner {
        max-width: 750px;
        margin: 0 auto;
    }

    header .header-inner div:first-child {
        width: 35%;
    }

    header .header-inner div.header-cta {
        width: 40%;
    }
}


.cta {
    width: 84vw;
    margin: 18vw auto 9vw;
}

.cta a {
    display: block;
    margin-bottom: 20px;
    position: relative
}

.cta a img {
    box-shadow: 0px 4px 0 rgba(0, 0, 0, 0.4);
    border-radius: 5px;
}

.cta a img.cta-gold {
    position: absolute;
    box-shadow: none;
    top: 0;
    left: 50%;
    transform: translate(-50%, -80%);
    width: 75%;
}

.header-cta a img {
    box-shadow: 0px 2px 0 rgba(0, 0, 0, 0.4);
    border-radius: 4px;
}

.header-cta a:first-child {
    margin-right: 8px;
}

.cta a:active img,
.header-cta a:active img {
    box-shadow: none;
    margin: 3px auto -3px;
}

@media screen and (min-width:751px) {
    .cta {
        width: 84%;
        margin: 140px auto 80px;
    }

    .cta a {
        margin-bottom: 50px;
    }

    .cta a img,
    .cta-row a img {
        border-radius: 10px;
    }

    .header-cta a img {
        border-radius: 6px;
    }

    .cta a:hover img,
    .header-cta a:hover img {
        box-shadow: none;
        margin: 3px auto -3px;
    }

    .header-cta a:first-child {
        margin-right: 16px;
    }
}


/*photo-wedding*/
.photo-wedding-bnr {
    width: 90vw;
    margin: 5% auto 0;
}

@media screen and (min-width: 750px) {
    .photo-wedding-bnr {
        width: 90%;
    }
}

.customers-voice {
    margin-top: 30px;
    margin-bottom: 30px;
}

.voice-slides {
    text-align: center;
}

.reason .reason-contents {
    margin-bottom: 40px;
}

.reason .reason-contents img {
    margin-top: 30px;
}

.photo-wedding .swiper-preview-slides {
    padding-bottom: 40px;
}

.photo-wedding .swiper-btn-relative {
    margin-top: -100vw;
    margin-bottom: 6vw;
}

@media screen and (min-width:751px) {
    .photo-wedding .swiper-btn-relative {
        margin-top: -100%;
        margin-bottom: 60px;
    }
}

.photo-wedding-slides .swiper-slide {
    text-align: center;
}

.photo-wedding-slides .swiper-slide img {
    width: 75vw;
    margin: 0 auto;
}

@media screen and (min-width:751px) {
    .photo-wedding-slides .swiper-slide img {
        width: 95%;
    }
}

.photo-wedding-slides .swiper-slide img.swiper-text-area {
    margin-top: -4vw;
    padding-bottom: 8vw;
}

@media screen and (min-width:751px) {
    .photo-wedding-slides .swiper-slide img.swiper-text-area {
        margin-top: -6%;
        padding-bottom: 80px;
    }
}

/* 表示されているスライドのテキスト */
.swiper-slide-active .swiper-text-area {
    /* animation-delay: 2s; */
    animation-duration: 1s;
    animation-fill-mode: both;
    animation-name: fadeIn;
}

/* アニメーション */
@keyframes fadeIn {
    from {
        opacity: 0;
        /* transform: translateY(30px); */
    }

    to {
        opacity: 1;
        /* transform: translateX(0); */
    }
}

.photo-wedding .swiper-button-next,
.photo-wedding .swiper-button-prev {
    top: 30%;
}

.wedding-dress div {
    background-color: #f1ebdd;
    padding: 10% 0;
    text-align: center;
}

.wedding-dress div p {
    font-family: YuMincho, "Hiragino Mincho ProN", serif;
    font-size: 4vw;
}
div.dress-cp {
    padding-bottom: 5%;
}
.dress-cp-img {
    width: 90%;
}

@media screen and (min-width:751px) {
    .wedding-dress div p {
        font-size: 30px;
    }
}

.wedding-dress div a {
    margin: 6% 0;
    display: block;
}

.photo-gallery {
    margin: 20vw auto;
}

.photo-gallery .gallery-thumb {
    margin-bottom: 7vw;
}

@media screen and (min-width:751px) {
    .photo-gallery {
        margin: 160px auto;
    }

    .photo-gallery .gallery-thumb {
        margin-bottom: 80px;
    }
}

.wedding-photo-slides {
    text-align: center;
}


.church-info {
    text-align: center;
}

.church-info .text-area {
    margin-top: -8vw;
    margin-bottom: 8vw;
    margin-left: auto;
    margin-right: auto;
    width: 80%;
    /* box-shadow: 0 0 5px 2px rgb(0, 0, 0, 0.1); */
    filter: drop-shadow(3px 4px 3px rgb(0, 0, 0, 0.1));
}

@media screen and (min-width:751px) {
    .church-info .text-area {
        margin-top: -10%;
        margin-bottom: 7%;
    }
}

.photo-wedding-top {
    width: 90%;
    margin: 7% auto;
}

.photo-wedding-gallery {
    width: 90%;
    margin: 0 auto;
}

.photo-wedding-content .more-btn {
    margin-top: 10vw;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.3;
    padding: 3%;
}

.photo-wedding-content .more-btn .arrow {
    padding-left: 5%;
    font-size: 1.2em;
}

@media screen and (min-width:751px) {
    .photo-wedding-content .more-btn {
        margin-top: 60px;
    }
}

.salon .salon-inner {
    width: 80vw;
    margin-right: auto;
    margin-left: auto;
}

@media screen and (min-width:751px) {
    .salon .salon-inner {
        width: 80%;
    }
}

.salon .salon-btn {
    width: 70vw;
    margin: 4vw auto 0;
    display: flex;
    margin-top: 4vw;
    flex-wrap: wrap;
}

@media screen and (min-width:751px) {
    .salon .salon-btn {
        width: 80%;
        margin: -20px auto 0;
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
    }
}

.salon .salon-btn div {
    width: 32vw;
    margin: 1vw;
}

@media screen and (min-width:751px) {
    .salon .salon-btn div {
        width: 32%;
        margin: 0;
    }
}

.salon-details {
    margin-bottom: 40px;
}

.salon-details img {
    margin-top: 30px;
    margin-bottom: 10px;
    box-shadow: 0 0 8px rgb(0, 0, 0, 0.1);
}

.anchor {
    padding-top: 70px;
    margin-top: -70px;
}

.flow {
    background-color: #f5f3f1;
    padding-bottom: 40px;
    ;
}

.flow-title {
    width: 70vw;
    margin: auto;
    padding-top: 20px;
    padding-bottom: 20px;
}

@media screen and (min-width:751px) {
    .flow-title {
        width: 70%;
        padding-top: 40px;
        padding-bottom: 40px;
    }
}

.step-slides {
    text-align: center;
}

.step-slides img {
    width: 80vw;
}

@media screen and (min-width:751px) {
    .step-slides img {
        width: 80%;
    }
}

footer {
    background-color: #53441e;
    text-align: center;
    color: #fff;
}


footer a {
    color: #fff;
}

.footer-logo {
    width: 40vw;
    margin: 0 auto;
    padding-top: 5vw;
    padding-bottom: 4vw;
}

@media screen and (min-width:751px) {
    .footer-logo {
        width: 35%;
        margin: 0 auto;
        padding-top: 30px;
        padding-bottom: 20px;
    }
}

.copy {
    display: block;
    padding-top: 4vw;
    padding-bottom: 4vw;
}

@media screen and (min-width:751px) {
    .copy {
        display: block;
        padding-top: 20px;
        padding-bottom: 20px;
        font-size: 12px;
    }
}

.text-indent {
    text-indent: -1em;
    padding-left: 1em;
}

#scheduled_img {
    line-height: 0;
}

.goldenweek {
    position: relative;
    margin-top: 30px;
}

.goldenweek p {
    position: absolute;
    bottom: 6vw;
    padding: 0 7%;
    line-height: 1.6;

}

@media screen and (min-width: 751px) {
    .goldenweek p {
        bottom: 80px;
    }
}

.church-recommendation {
    margin-top: 40px;
}

@media screen and (min-width: 751px) {
    .church-recommendation {
        margin-top: 60px;
    }

}

.youtube {
    width: 90%;
    margin: 0 auto;
    text-align: center;
    padding: 10% 0;
}

.youtube iframe {
    max-width: 100%;
    /* margin: 0 auto; */
    /* height: auto; */
}

a.more-btn {
    border: 1px solid #4c3d30;
    cursor: pointer;
    display: block;
    width: 8em;
    font-size: 4.2vw;
    /* margin-bottom: 10px; */
    margin: 0 auto 10vw;
    /* padding: 10px 40px 10px 20px; */
    padding: 0.5em 1.5em;
    position: relative;
    color: #4c3d30;
    border-radius: 100px;
    text-align: center;
    text-decoration: none;
    color: #4c3d30;
}



@media screen and (min-width: 751px) {
    a.more-btn {
        font-size: 24px;
        margin: 0 auto 60px;

    }
}

a.more-btn:hover,
a.more-btn:active {
    background-color: #4c3d30;
    color: #fff;
    transition-delay: 0.05s;
}

a.more-btn.more2 {
    width: 16em;
}

/* .dress-plan {
    margin-bottom: 40px;
} */