/*----------共通パーツ----------*/
.news .section_ttl,
.use .section_ttl,
.blog .section_ttl{
    text-align: center;
}



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



/*メインビュー*/
.main_view{
    width:1200px;
    margin:1.875rem auto 0 auto;
    position: relative;
    z-index: 2;
}
.main_view img{
    width:100%;
    height:auto;
}
.bg_txt{
    position: absolute;
    top:3.66vw;
    left:3.66vw;
}
.bg_txt h2{
    display: inline-block;
    background-color:white;
    padding:0 0.938rem;
    font-size: 2.125rem;
}
.bg_txt h2:first-of-type{
    margin-bottom:1.25rem;
}
.main_view p{
    color:white;
    position: absolute;
    top:3.66vw;
    right:3.66vw;
    font-weight: 400;
}


/*カフェについて*/

.introduction{
    width:1200px;
    margin:3.438rem auto 0 auto;
}

.introduction_content{
    position: relative;
}
.introduction_info{
    width:555px;
}
.introduction_copy{
    font-size: 1.875rem;
    font-weight: 700;
    margin:1.25rem 0 1.875rem 0;
}
.introduction_txt{
    width:100%;
    line-height:1.75rem;
    font-weight: 400;
}
.introduction .more_btn{
    margin-top:2.5rem;
}

.introduction_img{
    width:915px;
    height:456px;
    position: absolute;
    top:0;
    right:-400px;
}
.introduction_img img{
    width:100%;
    height:100%;
    object-fit: cover;
    object-position:-30px 95%;
    border-radius: 2.5rem 0 0 2.5rem;
}






/*新着情報・イベント情報*/
.news{
    margin-top: 14.938rem;
    background-color: #FAE9D2;
    position: relative;
    z-index: 2;
}
.news svg:first-of-type{
    transform: scale(-1,-1);
    top:-2.5rem;
}
.news svg:last-of-type{
    bottom:-30%;
}

.news_content{
    width:1000px;
    position: relative;
    top:0;
    left:50%;
    transform: translateX(-50%);
    z-index: 3;
}


.post_archive{
    width:1000px;
    background-color: white;
    padding:5.625rem 0;
    border-radius: 1.25rem;
    margin:3.25rem auto 0 auto;
}
.post_archive ul{
    width:800px;
    margin:0 auto;
}
.post_archive ul li{
    margin-bottom:1.875rem;
}
.post_archive ul li:last-of-type{
    margin-bottom:0;
}
.post_archive ul li a{
    color:#502200;
}
.post_archive ul li a div{
    display: flex;
    align-items: center;
    width:100%;
}
.post_archive ul li a div .post_ttl{
    width:100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.post_archive .post_ttl{
    margin-left: 1.875rem;
}
.post_archive .arrow{
    width:2rem;
    height:1.875rem;
    background-color: #502200;
    border-radius: 999999px;
    position: relative;
}
.post_archive .arrow::after{
    content:"";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 0.25rem solid transparent;
    border-bottom: 0.25rem solid transparent;
    border-left: 0.5rem solid #ffffff;
    border-right: 0;
    position: absolute;
    top:50%;
    left:53%;
    transform: translate(-50%,-50%);
}
/*あしらい*/
.box_img{
    width:190px;
    height:190px;
    position: absolute;
    top:-20%;
    left:13.4%;
}
.leaf_img{
    width:232.78px;
    height:auto;
    position: absolute;
    top:-24.5%;
    right:6.08%;
    z-index: -1;
}
.txt_treat{
    width:200.26px;
    height:auto;
    position: absolute;
    z-index: 2;
    top:5%;
    right:15.5%;
}







/*今日もゆるっとカフェのある暮らし*/
.info{
    margin-top:15rem;
    position: relative;
}
.info svg{
    transform: scale(-1,-1);
    bottom:-48%;
    z-index: -1;
}

.info_content{
    text-align: center;
    padding-bottom:11rem;
}
.info_content img{
    width:247px;
    height:auto;
}
.info_content .info_copy{
    font-size: 1.875rem;
    font-weight: 700;
    line-height:3rem;
    margin:0.625rem 0 1.875rem 0;
}
.info_content .info_txt{
    width:73.21%;
    margin:0 auto;
    font-weight: 400;
    line-height:1.75rem;
}


/*あしらい*/
.organic_txt{
    font-family: "Train One", system-ui;
    font-weight: 400;
    font-style: normal;
    color:#F7E9D6;
    font-size: 9.188rem;
    position: absolute;
    bottom:-1%;
    left:50%;
    transform: translateX(-50%);
    width:100%;
    text-align: center;
}
.people{
    width:clamp(451px, 40.34vw, 551px);
    height:auto;
    position: absolute;
    bottom:-39%;
    left:50%;
    transform: translateX(-50%);
    z-index: 2;
}
.organic_treat{
    width:201.28px;
    height:auto;
    position: absolute;
    bottom:-3%;
    left:15%;
}





/*楽しみ方*/
.use{
    margin-top:28rem;
}
.used_wrapper{
    width:1200px;
    margin:1.875rem auto 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.used_content{
    width:555px;
}
.used_content:nth-of-type(n+3){
    margin-top:5.625rem;
}
.used_content img{
    width:100%;
    height:auto;
    border-radius: 1.25rem;
}
.used_content h4{
    font-size: 1.5rem;
    margin:1.875rem 0 0.938rem 0;
}
.used_content p{
    font-weight: 400;
    line-height: 1.75rem;
}
.use .more_btn{
    margin-top:3.25rem;
}





/*ブログ*/
.blog{
    margin-top:25.25rem;
    background-color: #FAE9D2;
    position: relative;
}
.blog svg:first-of-type{
    transform: scale(-1,-1);
    top:-14vw;
    z-index: -1;
}
.blog svg:last-of-type{
    bottom:-5%;
    z-index: -1;
}

.blog_content{
    position: relative;
    top:-99px;
    width:1200px;
    margin:0 auto;
}
.blog_wrapper{
    width:100%;
    /* display: flex;
    flex-wrap: wrap;
    justify-content: space-between; */
    margin-top:1.875rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}
.blog_wrapper article{
    width:calc((100% - 6%) / 3);
    width: 100%;
}
.blog_wrapper article:nth-of-type(n+4){
    margin-top:3.75rem;
}
.blog_wrapper article a{
    color:#502200;
}
.blog_wrapper article img{
    width:100%;
    height:260px;
    border-radius: 1.25rem;
    object-fit: cover;
}
.blog_wrapper article .date{
    font-size: 0.875rem;
    margin-top:1.875rem;
}
.blog_wrapper article .post_ttl{
    font-size: 1.25rem;
    font-weight: 700;
    margin:0.313rem 0 0.938rem 0;
}
.blog_wrapper article a .excerpt{
    font-weight: 400;
    color:#2B2B2B;
}

.blog .more_btn{
    margin-top:4.188rem;
    display: flex;
    justify-content: center;
}
/*あしらい*/
.box_2{
    width:190px;
    height:190px;
    position: absolute;
    top:-22%;
    right:13.4%;
}




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

1440px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:1440px){
    .main_view,
    .introduction,
    .used_wrapper,
    .blog_content{
        width: clamp(1130px, 83.33vw, 1200px);
    }

}


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

1200px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:1200px){
    .main_view,
    .introduction,
    .news_content,
    .used_wrapper,
    .blog_content{
        width: clamp(900px, 83.33vw, 1000px);
    }

    /*メインビュー*/
    .main_view{
        margin: 0.875rem auto 0 auto;
    }

    /*カフェについて*/
    .introduction_txt{
        width: 80%;
    }
    .introduction_img{
        width:clamp(815px,76.25vw,915px);
        height:clamp(439px,38vw,456px);
    }


    /*新着情報*/
    .post_archive{
        width:100%;
    }
    .post_archive ul{
        width: clamp(700px, 66.67vw, 800px);
    }


    /*今日もゆるっと*/
    .organic_txt{
        font-size: 10.76vw;
    }
    .people{
        bottom: -30%;
    }
    .info svg{
        bottom: -36%;
    }



    /*楽しみ方*/
    .use {
         margin-top: 23rem;
    }
    .used_content {
        width: clamp(430px, 40.83vw, 490px);
    }


    /*ブログ*/
    .blog_wrapper article img{
        height: 18vw;
    }


}



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

1024px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:1024px){
    .introduction,
    .news_content,
    .used_wrapper,
    .blog_content{
        width: clamp(856px, 87.89vw, 900px);
    }


    /*カフェについて*/
    .introduction_img{
        width:clamp(715px,79.59vw,815px);
        height:clamp(356px,44.53vw,456px);;
        right: -330px;
    }
    .introduction_info {
        width: 480px;
    }


    /*新着情報*/
    .post_archive ul {
        width: 90%;
    }
    .news svg:last-of-type {
        bottom: -20%;
    }
    /*あしらい*/
    .box_img{
        width: clamp(150px, 18.55vw, 190px);
        height: clamp(150px, 18.55vw, 190px);
    }
    .leaf_img{
        width: clamp(150px, 22.73vw, 232.78px);
    }
    .txt_treat{
        width: clamp(150px, 19.56vw, 200.26px);
        right: 4.5%;
    }
    .organic_treat{
        width: clamp(130px, 14.66vw, 201.28px);
    }



    /*楽しみ方*/
    .used_content {
        width: clamp(400px, 41.99vw, 430px);
    }


    /*ブログ*/
    .box_2{
        width: 150px;
        height: 150px;
        top: -20%;
    }


}




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

890px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:890px){
    .main_view,
    .introduction,
    .news_content,
    .used_wrapper,
    .blog_content{
        width: clamp(750px, 92.13vw, 820px);
    }


    /*メインビュー*/
    .main_view {
        margin: 200px auto 0 auto;
    }



    /*カフェについて*/
    .introduction{
        padding-bottom: 30rem;
    }
    .introduction .section_ttl{
        text-align: center;
    }
    .introduction_info {
        width: 100%;
    }
    .introduction_txt {
        width: 100%;
    }
    .introduction_img {
        width: 1200px;
        height: 450px;
        top: 90%;
        left: 0;
    }
    .introduction_img img{
        object-position: -30px 60%;
    }
    .introduction .more_btn{
        position: relative;
        top: 510px;
    }




    /*新着情報*/
    /*あしらい*/
    .leaf_img{
        width: 150px;
        top: -20.5%;
        right: 15.08%;
    }
    .txt_treat{
        width: 150px;
        top: -9%;
        right: 9.5%;
    }




    /*今日もゆるっと*/
    .people{
        width: clamp(350px, 61.91vw, 551px);
        bottom: -30vw;
    }
    .info_content {
        padding-bottom: 18.88vw;
    }
    .info_content .info_txt{
        width: 90%;
        text-align: left;
    }
    .info::after{
        content:"";
        display: block;
        position: absolute;
        bottom: -300px;
        width:100%;
        height:91.1px;
        background-color: #F0B760;
    }
    .info svg {
        bottom: -29vw;
    }
    .organic_treat{
        bottom: 7vw;
        left: auto;
        right: 7vw;
    }


    /*楽しみ方*/
    .use {
        margin-top: 25rem;
    }
    .used_content {
        width: clamp(350px,44.94vw,400px);
    }


    /*ブログ*/
    .blog_wrapper {
        width: 80%;
        margin: 3.188rem auto 0 auto;
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
    .blog svg:first-of-type{
        top: -15vw;
    }
    .blog_wrapper article{
        width: calc((100% - 6%) / 2);
        width: 100%;
    }
    article:nth-of-type(n+3),
    .blog_wrapper article:nth-of-type(n+4){
        /* margin-top: 1.875rem; */
    }

    .blog_wrapper article img {
        height: 20vw;
    }
    .box_2{
        width:clamp(130px,19.53vw,150px);
        height:clamp(130px,19.53vw,150px);
        top: -23vw;
        right: 5vw;
    }


}





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

768px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:768px){


    .main_view,
    .introduction,
    .news_content,
    .used_wrapper,
    .blog_content{
        width: 95%;
    }

    /*メインビュー*/
    .main_view p{
        font-size: 2vw;
    }

    /*カフェについて*/
    .introduction_img {
        width: 900px;
        height: 345px;
    }
    .introduction_img img {
        object-position: -15px 60%;
    }
    .introduction .more_btn{
        top: 420px;
    }


    /*新着情報*/
    .news{
        margin-top: 8.125rem;
    }
    .news svg:last-of-type {
        bottom: -15%;
    }
    .post_archive {
        padding: 1.875rem 0;
    }
    .post_archive ul li a div{
        flex-flow: column;
        align-items: flex-start;
    }
    .post_archive ul li a div .post_link{
        width: 100%;
        display: flex;
        flex-flow: nowrap;
        align-items: center;
        justify-content: space-between;
    }
    .post_archive ul li a div .post_ttl{
        margin-left:0;
        margin-top:0.313rem;
        width: 85%;
    }
    .post_archive ul {
        width: 85%;
    }
    .post_archive .arrow{
        height: 2rem;
    }


    /*今日もゆるっと*/
    .info {
        margin-top: 10.125rem;
    }
    .info_content {
        padding-bottom: 114px;
    }
    .info svg {
        bottom: -28vw;
    }
    .info::after{
        bottom: -33vw;
    }
    .organic_treat {
        width: 16.93vw;
    }



    /*楽しみ方*/
    .use {
        margin-top: 20rem;
    }
    .used_content {
        width: 75%;
        margin: 0 auto;
    }
    .used_content:nth-of-type(n+2) {
        margin-top: 4.5rem;
    }
    .used_content h4{
        margin: 1.25rem 0;
        font-size: 1.25rem;
    }
    .use .more_btn {
        margin-top: 2.625rem;
    }


    /*ブログ*/
    .blog{
        margin-top: 40vw;
    }
    .blog_content{
        top: -8vw;
    }
    .blog_wrapper article .date{
        margin-top:0.938rem;
    }
    .blog_wrapper article .post_ttl {
        font-size: 1.125rem;
    }
    .blog svg:last-of-type{
        bottom: -8vw;
    }

}




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

600px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:600px){


    .main_view,
    .news_content,
    .used_wrapper,
    .used_content,
    .blog_content{
        width: 90%;
    }

    /*メインビュー*/
    .main_view{
        margin: 27.33vw auto 0 auto;
    }
    .bg_txt{
        top: 2.5rem;
        left: 0;
    }
    .bg_txt h2{
        padding: 0.625rem 0.938rem;
    }

    .main_view p {
        font-size: 1.25rem;
        font-weight: 500;
        top: 200px;
        right: auto;
        left: 12px;
        line-height:2.125rem;
    }



    /*新着情報*/
    .news {
        margin-top: 130px;
        padding-top: 2.875rem;
        z-index: auto;
    }
    .news svg:first-of-type{
        top: -30px;
    }
    .news svg:last-of-type {
        bottom: -12%;
    }
    .txt_treat{
        top: -7%;
    }
    .box_img {
        width: 116px;
        height: 116px;
        top: -14%;
        left: 4.4%;
    }
    .leaf_img{
        top: -16.5%;
        right: 6.08%;
    }
    .txt_treat{
        top: -6%;
        right: 3.5%;
    }


    /*今日もゆるっと*/
    .organic_txt {
        font-size: 12.76vw;
    }
    .info svg {
        bottom: -26%;
    }
    .people {
        width: 350px;
        bottom: -24%;
    }
    .info::after {
        bottom: -28%;
    }
    .organic_txt {
        font-size: 4.75rem;
        line-height: 5.188rem;
        bottom: -10%;
    }
    .organic_treat {
        width: 120px;
    }



    /*ブログ*/
    .blog_wrapper {
        width: 100%;
    }
    .blog_wrapper article img {
        height: 30vw;
    }
    .box_2{
        width:clamp(100px,21.67vw,130px);
        height:clamp(100px,21.67vw,130px);
    }


}



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

425px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:425px){
    /*共通パーツ------------------*/
    .section_ttl h3{
        font-size: 3.125rem
    }
    .section_ttl .section_ja{
        font-size: 1.625rem;
        line-height:2.75rem;
    }

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


    .main_view,
    .introduction,
    .news_content ,
    .used_wrapper,
    .blog_content{
        width: 89.33%;
    }

    /*メインビュー*/
    .main_view{
        margin: 24.53vw auto 0 auto;
    }
    .bg_txt{
        top: 1.875rem;
    }
    .bg_txt h2 {
        font-size: 1.5rem;
    }
    .main_view p{
        top: 11.188rem;
    }


    /*カフェについて*/
    .introduction{
        padding-bottom: 23rem;
    }
    .introduction_copy{
        font-size: 1.625rem;
    }
    .introduction_img {
        width: 520px;
        height: 250px;
    }
    .introduction .more_btn {
        top: 290px;
    }




    /*新着情報*/
    .news svg:last-of-type {
        bottom: -10%;
    }

    /*今日もゆるっと*/
    .info_content {
        padding-bottom: 180px;
    }

    .organic_txt {
        font-size: 5.75rem;
        line-height: 5.188rem;
    }
    .people{
        width:100%;
        bottom: -46vw;
    }
    .info svg{
        bottom: -17%;
    }
    .info_content .info_copy{
        font-size: 1.625rem;
    }
    .info::after {
        bottom: -50vw;
    }
    .organic_txt{
        bottom: -5%;
    }
    .organic_treat{
        bottom: 21vw;
        right: 7vw;
    }


    /*楽しみ方*/
    .use {
        margin-top: 18rem;
    }
    .used_content {
        width: 100%;
    }

    /*ブログ*/
    .blog_content {
        top: -3vw;
        padding-bottom: 2.5vw;
    }
    .box_2 {
        width: 116px;
        height: 116px;
    }
    .blog .more_btn{
        justify-content: flex-start;
    }
    .blog svg:last-of-type {
        bottom: -15vw;
    }

}






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

375px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:375px){
    .main_view,
    .introduction,
    .access_container,
    .footer_container{
        width: clamp(280px,89.33vw,335px);
    }

    /*メインビュー*/
    .bg_txt h2 {
        font-size: 1.4rem;
        padding: 0.375rem;
    }
    .bg_txt h2:first-of-type {
        margin-bottom: 0.75rem;
    }
    .main_view p{
        font-size: 1.05rem;
        top: 147px;
    }



    /*新着情報*/
    .news svg:last-of-type {
        bottom: -8%;
    }
    .post_archive ul li a div .post_ttl{
        width: clamp(200px, 56.8vw, 213px);
    }
    /*あしらい*/
    .news{
        margin-top: 130px;
        padding-top: 3.875rem;
    }
    .leaf_img {
        top: -14%;
        right: 7.08%;
    }
    .txt_treat {
        top: -5.5%;
        right: 3.5%;
    }



    /*今日もゆるっと*/
    .organic_txt {
        font-size: 4.75rem;
    }
    .people{
        bottom: -35vw;
    }
    .info svg {
        bottom: -11%;
    }
    .info::after {
        bottom: -16%;
    }
    .organic_txt {
        bottom: -1%;
    }
    .organic_treat{
        bottom: 31vw;
    }



    /*楽しみ方*/
    .use {
        margin-top: 14rem;
    }

    /*ブログ*/
    .blog {
        margin-top: 50.72vw;
    }
    .blog_wrapper article img {
        height: 29.33vw;
    }
    .blog_content {
        top: 3vw;
        padding-bottom: 7.5vw;
    }
    .blog svg:last-of-type {
        bottom: -16vw;
    }

}




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

320px以下

---------------------------------------------------------------------------------------------*/
@media(max-width:320px){

    /*メインビュー*/
    .main_view {
        margin: 26.53vw auto 0 auto;
    }

    .organic_txt {
        bottom: -3%;
    }
    .info svg {
        bottom: -8%;
    }
    .info::after {
        bottom: -14%;
    }
    .people {
        bottom: -37vw;
    }


    /*ブログ*/
    .box_2 {
        width: 100px;
        height: 100px;
    }

}