/* -----------------------------

プロポーズプラン
----------------------------- */
#propose *, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.goth {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    /* letter-spacing: 0.1rem; */
    text-align: justify;
    letter-spacing: 0.05rem;
}
.title{
    font-size: 4rem;
    font-family: goudy-old-style, serif;
    font-weight: 400;
    font-style: normal;
    color: #809E8A;
    letter-spacing: 3px;
    text-align: center;
}
.section-subtitle{
    display: block;
    font-size: 1.6rem;
    text-align: center;
}
.btn {
    display: inline-block;
    background-color: #809e8a;
    color: #fff !important;
    font-size: 1.3rem;
    padding: 1.5rem 6rem 1.5rem 3rem;
    /* margin: 3rem 3.5rem 0; */
    position: relative;
    margin: 0 auto;
    text-decoration: none;
}
.btn::before {
    content: "";
    position: absolute;
    display: block;
    background-color: #fff;
    width: 3rem;
    margin: auto;
    height: 0.1rem;
    right: 2rem;
    top: 50%;
}
.btn::after {
    content: "";
    position: absolute;
    display: block;
    background-color: #fff;
    margin: auto;
    height: 0.1rem;
    width: 0.8rem;
    right: 2.6rem;
    transform-origin: right bottom;
    transform: scaleX(1) rotate(-145deg);
    top: calc(50% - 5px);
}


@media screen and (min-width: 0px) and (max-width: 767px) {
    .btn {
        font-size: 13px;
        padding: 1.2rem 6rem 1.2rem 3rem;
    }
    .btn::before {
        width: 30px;
        height: 1px;
        right: 20px;
    }
    .btn::after {
        height: 1px;
        width: 8px;
        right: 26px;
    }
    .title{
        font-size: 30px;
        letter-spacing: 2px;
    }
    .section-subtitle{
        font-size: 12px;
    }

}

#propose{
    padding-bottom: 70px;
}

/* -----------------------------
メインビジュアル画像、導入の見出し部分
----------------------------- */
.main_image {
    margin-top: 81px;
}
.intro {
    text-align: center;
    margin: 6rem 0 10.4rem;
}
.intro h1 {
    font-size: 4rem;
    font-family: goudy-old-style, serif;
    font-weight: 400;
    font-style: normal;
    color: #809e8a;
    letter-spacing: 3px;
}
.intro > span {
    display: block;
    font-size: 1.6rem;
    color: #809e8a;
    letter-spacing: 0.1rem;
}
.intro p {
    font-size: 1.6rem;
    line-height: 2;
    margin-top: 4rem;
    margin-bottom: 5rem;
}


#proposal-plan .container{
    background-color: #f6f5f1;
    padding-bottom: 10rem;
}


#proposal-plan > .container >.title{
    position: relative;
    top: -3.5rem;
}

.plan-container{
    max-width: 100rem;
    margin: 0 auto;
}

.plan-container .plan-item{
    background-color: #fff;
    padding: 5rem 5.4rem;
    display: flex;
    justify-content: space-between;
    margin-bottom: 2.5rem;
}
.plan-container .plan-item .txt-box{
    width: 37rem;
}
.plan-container .plan-item .txt-box .price{
    color: #809e8a;
    font-size: 35px;
}
.plan-container .plan-item .txt-box .price span{
    font-size: 16px;
}
.plan-container .plan-item .txt-box h3{
    font-size: 16px;
    text-align: center;
    color: #809e8a;
    position: relative;
    margin: 4rem 0 2rem;
}

.plan-container .plan-item .txt-box h3::before,
.plan-container .plan-item .txt-box h3::after{
    position: absolute;
    content: "";
    display: block;
    width: 12rem;
    height: 1px;
    background-color: #809e8a;
    top: 50%;
}
.plan-container .plan-item .txt-box h3::before{
    left: 0;
}

.plan-container .plan-item .txt-box h3::after{
    right: 0;
}
.plan-container .plan-item .txt-box ul{
    line-height: 2;
}
#options .container{
    max-width: 100rem;
    margin: 5rem auto;
    background-color: #a29177;
    color: #fff;
    padding: 6rem 0;
}
#options .container .title{
    margin-bottom: 3.5rem;
}
#options .container .title,
#options .container .section-subtitle{
    color: #fff;
}
.options-container{
    display: flex;
    gap: 5rem 3.6rem;
    flex-wrap: wrap;
    justify-content: center;
}
.option-item{
    width: 28rem;
    text-align: center;
    font-size: 13px;
}
.option-item h3{
    font-size: 2rem;
    margin: 2rem 0;
}
.option-item p{
    text-align: center;
    letter-spacing: 0;
}
#data .container{
    max-width: 100rem;
    margin: 4rem auto;
    background-color: #fff;
    color: #a29177;
    padding: 6rem 4.5rem;
    display: flex;
    justify-content: space-between;
}
.data-item {
    max-width: 32rem;
    border-right: 1px solid #a29177;
    padding-right: 5rem;
}
.data-item:last-child{
    border: none;
    padding: 0;
}
.data-item h3{
    font-size: 2rem;
    margin-bottom: 2rem;
}
.data-item p{
    color: #666;
    font-size: 13px;
}

/* Points styles */
#points {
    padding: 120px 0;
    background-color: #FFFFFF; /* 背景は白 */
}
.points-container{
    margin-top: 5rem;
}
.point-item{
    position: relative;
    z-index: 1;
    padding: 7rem;
}
.point-item::after{
    content: "";
    display: block;
    width: 100%;
    height: 430px;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #F6F5F1;
    z-index: -1;
}
.point-item:last-child{
    padding-bottom: 0;
}
.point-head {
    position: relative;
}
.point-head .title{
    margin-bottom: 35px;
}
.point-number-bg {
    position: absolute;
    font-family: 'Goudy Old Style', serif;
    font-size: 130px; /* Figma style_VA6SA0 */
    color: rgba(128, 158, 138, 0.1); /* fill_P3YCO8, 少し薄く調整 */
    z-index: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    user-select: none; /* テキスト選択不可に */
}

.point-inner{
    width: 100rem;
    margin: 0 auto;
}
.point-item .point-img {
    display: flex;
    flex-wrap: wrap;
    align-items: center; /* 画像とテキストを中央揃え（垂直方向）*/
    justify-content: center;
    gap: 36px;
}
.point-item .point-img2 {
    display: flex;
    gap: 6px;
    justify-content: center;
}

.point-item .point-img img:first-child{
    width: 870px;
    margin: 0 auto;
}

.point-read  {
   text-align: center;
   margin: 50px 0;
   line-height: 2;
}

.point-details{
    display: flex;
    margin-bottom: 50px;
    align-items: center;
}
.point-details .point-txt{
    max-width: 460px;
    position: relative;
    z-index: 1;
    background-color: rgba(255, 255, 255, 0.7);
    padding: 70px 50px;
    right: -60px;
    line-height: 2.1;
}
.point-details + .point-details {
    flex-flow: row-reverse;
}
.point-details + .point-details .point-txt{
    right: auto;
    left: -60px;
}
.point03 .point-details .point-txt{
    right: auto;
    left: -60px;
}
.point-text h4 {
    font-family: 'Yu Mincho Pr6N', serif;
    font-size: 14px; /* Figma style_IRPV54 (チャペルなど) */
    color: #809E8A;
    margin-bottom: 15px;
}

.point-text p {
    font-family: 'Yu Gothic Pr6N', sans-serif;
    font-size: 14px; /* Figma style_95VR17 / style_XBFJXX */
    color: #444444;
    line-height: 2;
    margin-bottom: 10px;
}

.point-item .lunch{
    max-width: 780px;
    margin: 20px auto;
    background-color: #E9EEEA;
    text-align: center;
    padding: 30px 0 40px;
    margin-top: 50px;
}
.point-item .lunch h4{
    color: #809E8A;
    font-size: 18px;
    margin-bottom: 15px;
    letter-spacing: 0.15rem;
}

.contact-area .inner{
    background-color: #F6F5F1;
    outline: 1px solid #A29177;
    outline-offset: -10px;
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
    color: #A29177;
    padding: 35px 0;
    font-size: 16px;
}
.contact-area .inner h2{
    font-size: 20px;
}
.contact-area .inner a.tel{
    color: #A29177;
    text-decoration: none;
    font-size: 45px;
    display: block;
    font-family: goudy-old-style, serif;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.1rem;
}
.contact-area .inner a.tel span.text{
    font-size: 25px;
}
.contact-area .inner a.tel span.bar{
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.contact-area .inner .btn{
    background-color: #A29177;
    display: inline-block;
    margin-top: 20px;
}
#flow{
    background-color: #E9EEEA;
    padding-bottom: 100px;
    margin-bottom: 70px;
}
#flow .title.main{
    position: relative;
    top: -30px;
}
#flow .container{
   max-width: 1000px;
   margin: 0 auto;
}
.flow-block{
    max-width: 800px;
    margin: 0 auto 80px;
    background-color: #fff;
    padding: 35px 90px;
}
.flow-block h3{
    text-align: center;
    font-size: 22px;
    color: #809E8A;
    letter-spacing: 0.15rem;
    margin-bottom: 15px;
}
.flow-steps li{
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    display: flex;
    align-items: center;
    line-height: 2.4;
}
.flow-steps li strong{
    font-size: 22px;
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    color: #809E8A;
    margin-right: 10px;
}
.day-cases-container{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-top: 75px;
}
.day-case-item{
    width: 480px;
    background-color: #fff;
    position: relative;
}
.day-case-item h4{
    background-color: #809E8A;
    color: #fff;
    font-size: 18px;
    text-align: center;
    border-radius: 30px;
    position: absolute;
    top: -30px;
    width: 320px;
    margin: 0 auto;
    left: 0;
    right: 0;
    padding: 15px 0;
}
.day-case-item .timeline{
    padding: 25px 30px;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
.day-case-item .timeline li{
    display: flex;
    align-items: flex-start;
    gap: 15px;
    line-height: 2;
    border-bottom: 1px dashed #809E8A;
    padding-bottom: 25px;
    margin-bottom: 25px;
}
.day-case-item .timeline li:last-child{
    border: none;
    padding: 0;
    margin: 0;
}
.day-case-item .timeline li span{
    font-size: 18px;
    color: #809E8A;
    line-height: 1.6;
}

.flow-note{
    text-align: center;
    color: #809E8A;
    font-size: 18px;
    margin-top: 60px;
    line-height: 2.2;
    letter-spacing: 0.15rem;
}
.fix_bottom_pro{
    display: none!important;
}

@media screen and (min-width: 0px) and (max-width: 767px) {

    #propose{
        padding-bottom: 40px;
    }
    .main_image {
        margin-top: 55px;
    }
    .intro {
        margin: 40px auto 100px;
    }
    .intro h1 {
        font-size: 30px;
    }
    .intro span {
        font-size: 13px;
    }
    .intro p {
        font-size: 13px;
        line-height: 2;
        margin: 25px 0 30px;
        letter-spacing: 0.05rem;
    }

    #proposal-plan > .container >.title {
        position: relative;
        top: -27px;
    }
    #proposal-plan > .container{
        padding: 0 20px 20px;
    }
    .plan-container .plan-item{
        padding: 15px;
        display: block;
        margin-bottom: 20px;
    }
    .point-item::after{
        height: 200px;
    }
    .plan-container .plan-item .txt-box .price{
        text-align: center;
        font-size: 28px;
        margin-top: 25px;
    }
    .plan-container .plan-item .txt-box .price span{
        font-size: 14px;
    }
    .plan-container .plan-item .txt-box{
        width: 100%;
    }
    .plan-container .plan-item .txt-box h3{
        margin: 15px 0 10px;
    }
    .plan-container .plan-item .txt-box h3::before, .plan-container .plan-item .txt-box h3::after{
        width: 7.5rem;
    }
    #options .container{
        margin: 40px 0 0;
        padding: 30px 15px;
    }
    .options-container{
        display: block;
    }
    #options .container .title{
        margin-bottom: 15px;
    }
    .option-item{
        width: 100%;
        margin-bottom: 35px;
    }
    .option-item img{
        width: 100%;
    }
    .option-item h3{
        font-size: 18px;
        margin: 15px 0;
    }
    #data .container{
        display: block;
        padding: 25px 30px;
    }
    .data-item{
        border-right: none;
        border-bottom: 1px solid #a29177;
        padding: 0 0 20px 0;
        margin-bottom: 20px;
    }
    .data-item h3{
        font-size: 18px;
        margin-bottom: 10px;
    }
    #points{
        padding: 60px 0;
    }
    .points-container{
        margin-top: 30px;
    }
    .point-number-bg{
        font-size: 100px;
        top: 40%;
    }
    .point-item{
        padding: 50px 0 40px;
    }
    .point-item .point-img{
        gap: 10px 0;
        justify-content: space-between;
    }
    .point-inner{
        width: 100%;
    }
    .point-item .point-img img{
        width: 49%;
    }
    .point-item .point-img img:first-child{
        width: 100%;
    }
    .point-item.point02 .point-img img:nth-child(2),
    .point-item.point02 .point-img img:nth-child(3){
        height: 13.65rem;
        width: auto;
    }
    .point-read{
        margin: 30px 0;
    }
    .point-details{
        padding: 0 15px;
        margin-bottom: 30px;
    }
    .point-details,.point-details + .point-details{
        flex-flow: column-reverse;
    }
    .point03 .point-details{
        flex-flow: column;
    }
    .point-details .point-txt{
        position: static;
        padding: 10px 0 0;
    }
    .point-item .lunch{
        padding: 30px 40px;
        margin: 40px auto 10px;
    }
    .point-item .lunch h4{
        font-size: 16px;
    }
    .point-item .lunch .point-img2{
        gap: 4px;
    }
    .point-item .lunch .point-img2 img{
        width: 154px;
    }
    .point-item.point03 .point-img img:nth-child(2),
    .point-item.point03 .point-img img:nth-child(3){
        height: 13.5rem;
        width: auto;
    }
    .contact-area{
        padding: 0 20px ;
    }
    .contact-area .inner h2{
        font-size: 18px;
    }
    .contact-area .inner a.tel{
        font-size: 34px;
    }
    .contact-area .inner a.tel span.text{
        font-size: 16px;
    }
    .contact-area .inner{
        font-size: 13px;
    }
    #flow{
        padding-bottom: 50px;
        margin-bottom: 50px;
    }
    #flow .title.main{
        top: -26px;
    }
    #flow .container{
        padding: 0 15px
    }
    .flow-block{
        padding: 30px 20px;
        margin-bottom: 50px;
    }
    .flow-block h3{
        font-size: 18px;
    }
    .flow-steps li{
        align-items: flex-start;
        line-height: 1.8;
        margin-top: 20px;
    }
    .flow-steps li strong{
        font-size: 18px;
        line-height: 1.7;
    }
    .day-cases-container{
        display: block;
        padding: 0 5px;
        margin-top: 50px;
    }
    .day-case-item{
        width: 100%;
        margin-bottom: 70px;
    }
    .day-case-item:last-child{
        margin-bottom: 0;
    }
    .day-case-item h4{
        font-size: 15px;
        padding: 10px 0;
        width: 290px;
        letter-spacing: 0.1rem;
    }
    .day-case-item .timeline{
        padding: 20px;
    }

    .day-case-item .timeline li{
        display: block;
        padding-bottom: 20px;
        margin-bottom: 20px;
    }
    .day-case-item .timeline li span{
        font-size: 14px;
        display: block;
    }
    .flow-note{
        font-size: 15px;
        margin-top: 40px;
    }
    footer .is_top .fix_bottom_btn{
        display: none;
    }
    .point_slider img{
        margin: 0 3px;
        width: auto;
        height: 150px;
    }
    .fix_bottom_pro{
        display: block;
        position: fixed;
        font-size: 14px;
        letter-spacing: 0.1rem;
        width: 100%;
        bottom: 0;
        background-color: #d57474;
        z-index: 9999;
        text-align: center;
        transform: translateY(10px);
        opacity: 0;
        transition: all 0.6s ease; /* ふわっと表示用 */
    }
    .fix_bottom_pro.fix{
        transform: translateY(0);
        opacity: 1;
    }
}

