/* ========================================
   Lifestyle Page
======================================== */

.lifestyle_fv{
    position:relative;
    height:70vh;
    min-height:500px;
    max-height:800px;
    overflow:hidden;
    margin-bottom:80px;
}

.lifestyle_fv img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.lifestyle_fv_text{
    position:absolute;
    left:8%;
    bottom:12%;
    color:#fff;
    text-shadow:0 3px 10px rgba(0,0,0,.4);
}

.lifestyle_fv_text h1{
    font-size:5.4rem;
    line-height:1.35;
    margin-bottom:25px;
    font-weight:500;
    letter-spacing:.05em;
}

.lifestyle_fv_text p{
    font-size:1.8rem;
    line-height:2;
}

/* ========================================
   共通
======================================== */

body.page-template-page-rooftop-garden-life,
body.page-template-page-rooftop-garden-life p,
body.page-template-page-rooftop-garden-life li,
body.page-template-page-rooftop-garden-life dt,
body.page-template-page-rooftop-garden-life dd{
    font-family:"Yu Gothic","Yu Gothic UI","Hiragino Sans","メイリオ",sans-serif;
}

body.page-template-page-rooftop-garden-life h1,
body.page-template-page-rooftop-garden-life h2,
body.page-template-page-rooftop-garden-life h3{
    font-family:"Yu Gothic","Yu Gothic UI","Hiragino Sans","メイリオ",sans-serif;
}

.lifestyle_wrap{
    max-width:1280px;
    margin:0 auto;
    padding:0 40px;
}

.lifestyle_section{
    padding:140px 0;
}

.lifestyle_section.gray{
    background:#f7f7f7;
}

.lifestyle_section.beige{
    background:#f5f0ea;
}

.lifestyle_section.dark{
    background:#111;
    color:#fff;
}

.lifestyle_inner{
    display:flex;
    align-items:center;
    gap:120px;
}

.lifestyle_inner.reverse{
    flex-direction:row-reverse;
}

.lifestyle_img{
    flex:1;
}

.lifestyle_img img{
    width:100%;
    height:auto;
    display:block;
    border-radius:50px !important;
}

.lifestyle_txt{
    flex:1;
}

.lifestyle_en{
    font-size:1.4rem;
    letter-spacing:.45em;
    color:#999;
    margin-bottom:25px;
    font-weight:500;
    text-transform:uppercase;
}

.dark .lifestyle_en{
    color:#ccc;
}

.lifestyle_txt h2{
    font-size:3.8rem;
    line-height:1.5;
    margin-bottom:30px;
    font-weight:500;
    letter-spacing:.05em;
}

.lifestyle_txt p{
    font-size:1.8rem;
    line-height:2.6;
    letter-spacing:.03em;
}

/* ========================================
   Full Image
======================================== */

.lifestyle_full{
    text-align:center;
}

.lifestyle_full img{
    width:100%;
    height:auto;
    display:block;
    border-radius:50px !important;
    margin-bottom:50px;
}

.lifestyle_full h2{
    font-size:3.8rem;
    margin-bottom:25px;
    font-weight:500;
    letter-spacing:.05em;
}

.lifestyle_full p{
    max-width:800px;
    margin:0 auto;
    line-height:2.6;
    font-size:1.8rem;
    letter-spacing:.03em;
}

/* ========================================
   Kids Area
======================================== */

.lifestyle_grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
    margin-bottom:50px;
}

.lifestyle_grid img{
    width:100%;
    border-radius:50px !important;
    display:block;
}

/* ========================================
   CTA
======================================== */

.lifestyle_cta{
    text-align:center;
    padding:140px 30px;
}

.lifestyle_cta h2{
    font-size:4.2rem;
    margin-bottom:30px;
}

.lifestyle_cta p{
    font-size:1.8rem;
    line-height:2;
    margin-bottom:40px;
}

.lifestyle_btn{
    display:inline-block;
    background:#1d4d8f;
    color:#fff;
    padding:18px 50px;
    border-radius:40px !important;
    text-decoration:none;
    font-size:1.8rem;
    transition:.3s;
}

.lifestyle_btn:hover{
    opacity:.8;
}

.lifestyle_note{
    margin-top:30px;
    text-align:center;
    font-size:1.2rem;
    line-height:1.8;
    color:#999;
}

/* ========================================
   Responsive
======================================== */

@media screen and (max-width:768px){

    .lifestyle_fv{
        height:45vh;
        min-height:320px;
        margin-bottom:50px;
    }


    .lifestyle_fv_text{
        left:6%;
        right:6%;
        bottom:8%;
    }

    .lifestyle_fv_text h1{
        font-size:3.0rem;
    }

    .lifestyle_fv_text p{
        font-size:1.5rem;
    }

    .lifestyle_section{
        padding:70px 0;
    }

    .lifestyle_inner,
    .lifestyle_inner.reverse{
        flex-direction:column;
        gap:40px;
    }

    .lifestyle_txt h2{
        font-size:2.8rem;
    }

    .lifestyle_txt p{
        font-size:1.6rem;
    }

    .lifestyle_grid{
        grid-template-columns:1fr;
    }

    .lifestyle_full h2{
        font-size:2.8rem;
    }

    .lifestyle_cta{
        padding:80px 20px;
    }

    .lifestyle_cta h2{
        font-size:3.0rem;
    }
}