@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: 750px) {
    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: 750px) {
    .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;
}

.insta-showcase {
    position: relative;
    overflow: hidden;
}

.inta-slide-img .swiper-slide .swiper-slide-img {
    /* width: 60vw !important; */
    height: auto;
    /* margin: 0 2.5vw; */
}


@media screen and (min-width:600px) {
    .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: 600px) {
    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: 16vw auto 9vw;
}

.cta a {
    display: block;
    margin-bottom: 20px;
    position: relative;
}

.cta a img.cta-gold {
    position: absolute;
    box-shadow: none;
    top: 0;
    left: 50%;
    transform: translate(-50%, -80%);
    width: 85%;
}


.cta a img {
    box-shadow: 0px 4px 0 rgba(0, 0, 0, 0.4);
    border-radius: 5px;
}

.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: 750px) {
    .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 {
    background-color: #f4f0ea;
}

.photo-wedding a {
    width: 90vw;
    margin: 0 auto;
    display: block;
    padding-top: 3%;
}

.cta-bg-beige {
    margin: 0 auto;
    width: 100%;
    padding: 9vw 0;
    background-color: #f4f0ea;
}

.cta-bg-beige a {
    width: 84vw;
    margin: 0 auto 20px;
}

@media screen and (min-width: 750px) {

    .photo-wedding a {
        width: 90%;
    }

    .cta-bg-beige {
        padding: 80px 0;
    }

    .cta-bg-beige a {
        width: 84%;
        margin: 0 auto 50px;
    }
}

.campaign {
    background-color: #f4f0ea;
    text-align: center;
    padding-bottom: 20px;
}

.campaign ul li {
    list-style: none;
}

.campaign ul li {
    width: 90%;
    margin: 10% auto;
}

.accordion2-btn {
    border: 1px solid #4c3d30;
    cursor: pointer;
    display: inline-block;
    font-size: 18px;
    margin-bottom: 10px;
    padding: 10px 40px 10px 20px;
    position: relative;
    color: #4c3d30;
}

/*アイコンの＋と×*/
.more::before,
.more::after {
    position: absolute;
    content: '';
    width: 15px;
    height: 2px;
    background-color: #4c3d30;

}

.more::before {
    top: 48%;
    right: 12px;
    transform: rotate(0deg);

}

.more::after {
    top: 48%;
    right: 12px;
    transform: rotate(90deg);

}

.close::before,
.close::after {
    position: absolute;
    content: '';
    width: 15px;
    height: 2px;
    background-color: #4c3d30;

}

.close::before {
    top: 48%;
    right: 12px;
    transform: rotate(45deg);

}

.close::after {
    top: 48%;
    right: 12px;
    transform: rotate(-45deg);

}

.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-gallery {
    margin: 10vw auto;
}

.photo-gallery .gallery-thumb {
    margin-bottom: 7vw;
}

@media screen and (min-width: 750px) {
    .photo-gallery {
        margin: 100px auto;
    }

    .photo-gallery .gallery-thumb {
        margin-bottom: 80px;
    }
}

.wedding-photo-slides {
    text-align: center;
}

.salon .salon-inner {
    width: 80vw;
    margin-right: auto;
    margin-left: auto;
}

@media screen and (min-width: 750px) {
    .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: 750px) {
    .salon .salon-btn {
        width: 80%;
        margin: -20px auto 0;
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-evenly;
    }
}

.salon .salon-btn div {
    width: 32vw;
    margin: 1vw;
}

@media screen and (min-width: 750px) {
    .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: 750px) {
    .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: 750px) {
    .step-slides img {
        width: 80%;
    }
}

.notes {
    width: 95%;
    margin: 10px auto 20px;
    border: 1px solid #53441e;
}

.notes p {
    padding: 1em 1em 0 1em;
}

.notes ul {
    padding: 1em;
}

.notes ul li {
    list-style: none;
    line-height: 1.2;
    margin-bottom: 0.5em;

}

.text-indent {
    text-indent: -1em;
    padding-left: 1em;
}

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: 750px) {
    .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: 750px) {
    .copy {
        display: block;
        padding-top: 20px;
        padding-bottom: 20px;
        font-size: 12px;
    }
}

#scheduled_img {
    line-height: 0;
}

.goldenweek {
    position: relative;
    margin-top: 30px;
}

.goldenweek div {
    position: absolute;
    bottom: 6vw;
    padding: 0 5%;
    line-height: 1.6;

}

@media screen and (min-width: 751px) {
    .goldenweek div {
        bottom: 120px;
    }
}

.campaign .condition {
    border: 1px solid #4c3d30;
    width: 90%;
    margin: 20px auto;
    padding: 1em 0;
}

@media screen and (min-width: 751px) {
    .campaign .condition {
        font-size: 16px;
    }
}

.campaign .condition p {
    font-family: "游明朝体", "Yu Mincho", YuMincho, sans-serif;
    font-size: 1.5em;
    border-bottom: 1px solid #333;
    display: inline-block;
    line-height: 1.3;
    margin-bottom: 1em;
}

.campaign .condition ul {
    text-align: left;
}

.campaign .condition ul:first-of-type {
    margin-bottom: 2em;
}

.campaign .condition ul li {
    margin: 0 auto 0.4em;
}


a.more-btn {
    border: 1px solid #4c3d30;
    cursor: pointer;
    display: block;
    width: 10em;
    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;
}

/*photo-wedding-content*/
.photo-wedding-content {
    background-color: #f4f0ea;
    padding-bottom: 10vw;
}

.photo-wedding-top {
    width: 90%;
    margin: 7% auto;
}

.photo-wedding-gallery {
    width: 100%;
    margin: 0 auto;
}

.photo-wedding-content .more-btn {
    margin-top: 10vw;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0;
    line-height: 1.3;
    padding: 3%;
}

.photo-wedding-content .more-btn .arrow {
    padding-left: 5%;
}

@media screen and (min-width:751px) {
    .photo-wedding-content .more-btn {
        margin-top: 60px;
    }

    .photo-wedding-content {
        padding-bottom: 60px;
    }
}

/*fv下の注釈*/
.fv-bnr-wrapper {
    background-color: #f4f0ea;
    padding-bottom: 9vw;
    margin-bottom: -9vw;
}

.fv-bnr-wrapper .note,
.flower-shower-cp .note {
    text-align: right;
    color: #593501;
    padding: 2% 0 0;
    width: 90%;
    margin: 0 auto;
    font-weight: 400;
    background-color: #f4f0ea;
    font-size: 1rem;
}

.flower-shower-cp .note {
    padding: 0 0;
    margin-bottom: 4%;
    margin-top: 1%;
}

.treatment-wrapper .note-toggle {
    text-align: left;
    padding-right: 0;
}

.treatment-wrapper .note-toggle .toggle-content {
    list-style-type: disc;
}

/*Toggle*/
.toggle {
    color: #593501;
    text-align: left;
    /* border-bottom: 1px solid #ddd; */
    padding-left: 3%;
    margin: 0 auto;
    word-wrap: 10%;
    padding: 1% 0;
    width: 90%;
    font-family:
        "ヒラギノ角ゴ ProN",
        "Hiragino Kaku Gothic ProN",
        "游ゴシック",
        "Yu Gothic",
        "メイリオ",
        "Meiryo",
        sans-serif;
}

.toggle-section {
    padding-top: 1%;
}

.toggle-title {
    font-weight: bold;
}

.toggle-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    padding: 5px 5px 0;
    margin-bottom: 5px;
    text-align: right;
    color: #593501;
}

.toggle-header:hover {
    opacity: 0.8;
}

.toggle-content {
    display: none;
    padding-left: 20px;
}

/* .arrow {
    transition: transform 0.3s;
    padding-right: 1%;
} */

.toggle-content {
    display: block;
    padding: 0px 20px 5px;
}

/* .arrow {
    transform: rotate(180deg);
} */

/*宿泊プレゼントCP*/
.hotel-voucher {
    background-color: #f1ebdd;
}

.target-venue-title {
    width: 80%;
    margin: 0 auto;
    padding: 10% 0 5% 0;
}

.swiper-btn-relative.hotel-voucher .swiper-button-next {
    width: calc(var(--swiper-navigation-size) / 44 * 11);
    color: #333333;
}

.swiper-btn-relative.hotel-voucher .swiper-button-prev {
    width: calc(var(--swiper-navigation-size) / 44 * 11);
    color: #333333;

}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-size: 15px;
}

a.more-btn.other {
    margin: 0 auto;
    width: 14em;
}

.other-btn {
    padding: 3vw 0 10vw 0;
}


@media screen and (min-width: 751px) {
    .swiper-btn-relative.hotel-voucher .swiper-button-next {
        width: calc(var(--swiper-navigation-size) / 44 * 44);
        color: #333333;
    }

    .swiper-btn-relative.hotel-voucher .swiper-button-prev {
        width: calc(var(--swiper-navigation-size) / 44 * 44);
        color: #333333;
    }

    .swiper-button-next:after,
    .swiper-button-prev:after {
        font-size: 30px;
    }

    .other-btn {
        padding: 3% 0 10% 0;
    }
}