/********************************

	共通パーツ

********************************/
main img {
    width: 100%;
}

main p {
    line-height: 1.9;
    max-width: 900px;
}

.cmn-continer {
    margin: 2em 0;
}

.cmn-continer p {
    margin: 0 0.5em;
}

.cmn-continer img {
    object-fit: cover;
    object-position: 20% 20%;
    max-height: 400px;
}

.cmn-continer .text-box p {
    display: inline-block;
    margin: 0.5em 0;
}

.text-box {
    margin: 0 0.5em;
}

@media(min-width:700px) {
    .cmn-continer {
        margin: 2em 3em;
    }

    .cmn-continer p {
        margin: 2em 0.5em;
    }
}

main {
    margin: 0 auto;
    width: fit-content;
    max-width: 1100px;
}

/********************************

	1枚目の写真と説明文

********************************/
.mes-box h2 {
    color: var(--main100);
    font-weight: 900;
    width: fit-content;
    margin-left: 1em ;
}

.longdash {
    display: inline-block;
    background-color: var(--main100);
    inline-size: 4em;
    block-size: 2px;
    vertical-align: middle;
}

.img1 {
    max-width: 1100px;
} 

.cmn-continer .comname p {
    margin: 0;
    font-weight: bold;
    max-width: none;
    text-align: right;
}

.cmn-continer .comname .name {
    font-size: 2em;
}

@media(min-width:700px) {
    .mes-box {
        display: flex;
        margin: 0;
    }

    .mes-box h2 {
        writing-mode: vertical-rl;
        letter-spacing: 8px;
        background-color: white;
        position: relative;
        top: -65px;
        padding: 2em;
        margin: 0;
    }

    .longdash {
        display: inline-block;
        background-color: var(--main100);
        inline-size: 6em;
        block-size: 2px;
        vertical-align: unset;
    }
}


/********************************

	2枚目の写真と説明文

********************************/
.img2 {
    max-width: 790px;
}

/********************************

	3枚目の写真と説明文

********************************/
.img3 {
    max-width: 790px;
}

.cmn-continer .message {
    margin: 3em 0.5em;
}

@media(min-width:1000px) {
    .img3 {
        margin-left: 10em;
    }
}

/********************************

	おすすめコンテンツ  

********************************/
#recomend > hgroup {
    width: fit-content;
    margin: 5em auto 0 auto;
}

#recomend > hgroup >  p {
    width: fit-content;
    margin: 0.25em auto;
    letter-spacing: 1.5px;
}

.reco-box {
    margin: 3em 1em; 
}

.reco-box {
    margin: 2em 1em; 
}

.reco-box > img {
    width: 100%;
    height: 200px;
    max-width: 540px;
    border-radius: 0 20px 0 0;
    object-position: 50% 15%;
}

.reco-box img {
    object-fit: cover;
}

.box {
    font-weight: bold;
    background-color: white;
    padding: 10px 17px;
    margin-top: -3em;
    position: relative;
    z-index: 100;
    width: fit-content;
}

.box > p {
    background:  linear-gradient(90deg,var(--main0), var(--main100));
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0;
}

.box  span {
    font-size: 20px;
    color: black;
}


.box span::after {
    content: "";
    display: block;
    background-image: url(yazi.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 50px;
    height: 50px;
    position: absolute;
    right: -40px;
    bottom: 9px;
}

.recomend-wr a {
    text-decoration: none;
    flex-grow: 1;
    flex-basis: 50%;
}

@media(min-width:768px) {
    .recomend-wr {
        display: flex;
        margin: 2em auto;
        justify-content: center;
        max-width: 1100px;
    }
    .reco-box > img {
        max-width: 530px;
        object-position: center;
    }

    .box {
        display: flex;
        align-items: center;
        gap: 20px;
    }

    .box span::after {
        position: absolute;
        right: -41px;
        bottom: -1px;
    }
} 
