@charset "UTF-8";

/* メインビジュアル 動画 */
.main-visual {
    padding-top: 80px;
    position: relative;
}

.main-visual>img {
    width: 100%;
}

.mv_text {
    font-size: 3em;
    color: #ffffff;
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    width: 90%;
    text-align: center;
    font-family: zen-old-mincho, sans-serif;
    text-shadow: 0px 3px 6px #0000004D;
    font-weight: 700;
}

.mv_text .pc_none {
    display: none;
}

.mv-bg {
    width: 100%;
    height: 105px;
    background: url(../images/mv_bg.png) no-repeat right bottom / cover;
    background-size: 70% auto;
    margin-top: -5px;
}

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

    /* メインビジュアル 動画 */
    .main-visual {
        padding-top: 80px;
        position: relative;
    }

    .mv_text {
        font-size: 9vw;
        line-height: 1.5;
    }

    .mv_text .pc_none {
        display: block;
    }

    .mv-bg {
        width: 100%;
        height: 20vw;
        background: url(../images/mv_bg.png) no-repeat right bottom / cover;
        background-size: 100% auto;
        margin-top: -5px;
    }
}

/* News */
.news {
    background: url(../images/news_bg.png) no-repeat;
    width: 100%;
    height: 625px;
    background-size: 50% 100%;
}

.news-inner {
    width: 60%;
    margin: auto;
    padding: 250px 0;
}

.news-inner h2 {
    font-size: 3em;
    color: #5C4500;
    text-align: center;
    font-family: 'Cinzel', serif;
}

.news-inner span {
    text-align: center;
    display: block;
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 400;
    font-style: normal;
    color: #5C4500;
}

.news-heading {
  padding-bottom: 50px;
}

.news-inner dl.info {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    margin-bottom: 30px;
    border-bottom: 1px solid #ccc;
}

.news-content {
  margin-top: 10px;
}

.news-inner dl {
    margin: 0;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-height: 500px;
    overflow-y: scroll;
    overflow-x: hidden;
    /* IE, Edge 対応 */
    -ms-overflow-style: none;
    /* Firefox 対応 */
    scrollbar-width: none;
}

/* Chrome, Safari 対応 */
.news-inner dl::-webkit-scrollbar {
    display: none;
}

.news-inner dt {
    width: 8em;
}

.news-inner dt span {
    background-color: #fff;
    border-radius: 10px;
    padding: 5px 10px 3px;
    border: 1px #657D5A solid;
    color: #657D5A;
    font-family: yu-gothic-pr6n, sans-serif;
    font-style: normal;
    font-weight: bold;
}

.news-inner dd {
    flex: 1;
    padding: 5px 10px 20px 30px;
}

.news-inner dd a {
    color: #333333;
    background-image: linear-gradient(to right, #000, #000);
    padding-bottom: 0.25em;
    background-position: 100% 100%;
    background-size: 0% 1px;
    background-repeat: no-repeat;
    transition: background-size 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    font-weight: 700;
}

.news-inner dd a:hover {
    background-position: 0 100%;
    background-size: 100% 1px;
}

.spread-line {
    width: 50%;
    height: 1px;
    background-color: #009848;
    margin-left: auto;
    margin-right: 0;
    -webkit-animation: spread 1.4s ease-in-out infinite;
    animation: spread 1.4s ease-in-out infinite;
}

/* single */
.single-news-inner {
    padding: 40px 0;
}

.news-detail__content-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 800px;
    margin: 5px auto;
    padding: 5px 0;
    gap: 20px;
}
.news-detail__link {
    text-decoration: underline;
    color: #333;
    font-size: 16px;
    transition: color 0.3s ease;
}

.news-detail__link:hover {
    color: #666;
}

@-webkit-keyframes spread {
    0% {
        width: 0%;
        top: 0;
        opacity: 0;
    }

    50% {
        width: 60%;
        opacity: 1;
    }

    100% {
        width: 70%;
        top: 50px;
        opacity: 0;
    }
}

@keyframes spread {
    0% {
        width: 0%;
        top: 0;
        opacity: 0;
    }

    50% {
        width: 60%;
        opacity: 1;
    }

    100% {
        width: 70%;
        top: 50px;
        opacity: 0;
    }
}

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

    /* News */
    .news {
        background: url(../images/news_bg.png) no-repeat;
        width: 100%;
        height: 670px;
        background-size: 100% 100%;
    }

    .news-heading{
        padding-bottom: 20px;
    }

    .news-inner {
        width: 90%;
        margin: auto;
    }

    .news-inner h2 {
        font-size: 3em;
        color: #5C4500;
        text-align: center;
        font-family: 'Cinzel', serif;
    }

    .news-inner span {
        text-align: center;
        display: block;
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .news-inner dl {
        display: flex;
        align-items: flex-start;
        border-bottom: 1px solid #ccc;
        margin-bottom: 40px;
        padding: 0;
        flex-wrap: wrap;
}

    /* Chrome, Safari 対応 */
    .news-inner dl::-webkit-scrollbar {
        display: none;
    }

    .news-inner dt {
        width: 20%;
        border-bottom: none;
        display: flex;
        align-items: center; /* 日付縦中央揃え */
        padding-right: 15px;
    }

    .news-inner dt span {
        background-color: #fff;
        border-radius: 10px;
        padding: 5px 10px 3px;
        border: 1px #657D5A solid;
        color: #657D5A;
        font-family: yu-gothic-pr6n, sans-serif;
        font-style: normal;
        font-weight: bold;
    }

    .news-inner dd {
        width: 75%;
        padding: 0;
        margin-bottom: 10px;
    }

    .news-inner dd a {
        color: #333333;
        background-image: linear-gradient(to right, #000, #000);
        padding-bottom: 0.25em;
        background-position: 100% 100%;
        background-size: 0% 1px;
        background-repeat: no-repeat;
        transition: background-size 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
        font-weight: 700;
    }

    .news-inner dd a:hover {
        background-position: 0 100%;
        background-size: 100% 1px;
    }

    .news-inner .news-content {
        margin-top: 10px;
}

    .spread-line {
        width: 50%;
        height: 1px;
        background-color: #009848;
        margin-left: auto;
        margin-right: 0;
        -webkit-animation: spread 1.4s ease-in-out infinite;
        animation: spread 1.4s ease-in-out infinite;
    }

    @-webkit-keyframes spread {
        0% {
            width: 0%;
            top: 0;
            opacity: 0;
        }

        50% {
            width: 60%;
            opacity: 1;
        }

        100% {
            width: 70%;
            top: 50px;
            opacity: 0;
        }
    }

    @keyframes spread {
        0% {
            width: 0%;
            top: 0;
            opacity: 0;
        }

        50% {
            width: 60%;
            opacity: 1;
        }

        100% {
            width: 70%;
            top: 50px;
            opacity: 0;
        }
    }
}

@media screen and (max-width: 896px) {
.news-inner dl {
    display: block;
    border-bottom: 1px solid #ccc;
    margin-bottom: 40px;
    padding: 0;
}

.news-inner dt {
    width: 100%;
    margin-bottom: 10px;
    border-bottom: none;
}

.news-inner dd {
    width: 100%;
    padding: 0;
    margin-bottom: 10px;
}

.news-inner .news-content {
    margin-top: 10px;
}
}

/* Concept */
.concept {
    background: url(../images/concept_bg.png) no-repeat center center / cover;
    display: flex;
    padding: 100px 0;
}

.concept-l {
    width: 50%;
}

.concept-img01 {
    max-width: 700px;
    margin-bottom: 20px;
}

.concept-img02 {
    max-width: 500px;
    margin-left: auto;
    margin-right: 0;
}

.concept-img01 img,
.concept-img02 img {
    width: 100%;
}

.concept-r {
    width: 40%;
}

.concept-r-inner {
    padding: 80px 10%;
}

.concept-r h2 {
    color: #5C4500;
    font-size: 4em;
    text-align: center;
    font-family: 'Cinzel', serif;
}

.concept-r span {
    display: block;
    text-align: center;
    margin-bottom: 50px;
    color: #5C4500;
}

.concept-r p.c-txt01 {
    font-size: 2vw;
    text-align: center;
    line-height: 1.5;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    padding-bottom: 40px;
}

.concept-r p.c-txt01 span {
    font-size: .6em;
    padding-top: 35px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    color: #000;
}

.concept-r p.c-txt02 {
    font-size: 1.1em;
    line-height: 2;
    margin-bottom: 80px;
    font-family: zen-kaku-gothic-new, sans-serif;
    font-weight: 500;
    font-style: normal;
}

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

    /* Concept */
    .concept {
        background: url(../images/concept_bg.png) no-repeat center center / cover;
        display: block;
        padding: 50px 0 70vw;
    }

    .concept-l {
        width: 90%;
        margin: auto;
    }

    .concept-img01 {
        max-width: 700px;
        margin-bottom: 20px;
    }

    .concept-img02 {
        max-width: 500px;
        margin-left: auto;
        margin-right: 0;
    }

    .concept-img01 img,
    .concept-img02 img {
        width: 100%;
    }

    .concept-r {
        width: 90%;
        margin: auto;
    }

    .concept-r-inner {
        padding: 50px 10%;
    }

    .concept-r h2 {
        font-size: 3em;
        text-align: center;
        font-family: 'Cinzel', serif;
    }

    .concept-r span {
        display: block;
        text-align: center;
        margin-bottom: 50px;
    }

    .concept-r p.c-txt01 {
        font-size: 1.7em;
        text-align: center;
        line-height: 1.5;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .concept-r p.c-txt01 span:nth-of-type(1) {
        font-size: 1em;
        padding-top: 35px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        color: #009848;
        display: inline-block;
        margin: 0;
    }

    .concept-r p.c-txt01 span:nth-of-type(2) {
        font-size: 1em;
        padding-top: 35px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        color: #F5BE27;
        display: inline-block;
        margin: 0;
    }

    .concept-r p.c-txt01 span {
        font-size: .7em;
        padding-top: 35px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .concept-r p.c-txt02 {
        font-size: 1em;
        line-height: 2;
        margin-bottom: 80px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }
}

@media screen and (min-width: 897px) and (max-width:1300px) {
    .concept-r p.c-txt01 {
        font-size: 2.3vw;
        text-align: center;
        line-height: 1.5;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .concept-r p.c-txt01 span {
        font-size: .8em;
        padding-top: 35px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .concept-r p.c-txt02 {
        font-size: 1em;
        line-height: 2;
        margin-bottom: 80px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }
}

/* WELCOME */
.visit {
    width: 100%;
    padding: 140px 0 0;
}

.visit-inner {
    width: 100%;
    height: auto;
    background-color: #E9E5DD;
    position: relative;
    background: url(../images/bg01.png) no-repeat center / cover;
}

.aspect1-1:before {
    content: "";
    display: block;
    padding-top: 30%;
    /* 1:1 */
}

.visit-inner::after {
    content: "";
    position: absolute;
    height: 100%;
    width: 75%;
    top: -50px;
    left: 50%;
    transform: translateX(-50%);
    background: transparent radial-gradient(closest-side at 50% 50%, #345823 0%, #77A86E 83%, #8EAE83 100%) 0% 0% no-repeat padding-box;
    z-index: 1;
    /* padding-left: 33%; */
    margin-left: 5%;
}

.visit-txt {
    position: absolute;
    z-index: 4;
    top: 5%;
    left: 50%;
    transform: translateX(-50%);
    width: 25vw;
    margin-left: 3%;
}

.bt-visit {
    position: absolute;
    z-index: 5;
    background-color: #075E24;
    width: 280px;
    color: #fff;
    text-align: center;
    border: 1px #fff solid;
    top: 65%;
    left: 50%;
    transform: translateX(-50%);
}

.bt-visit a {
    width: 100%;
    height: 100%;
    padding: 20px 0;
    display: block;
}

.visit-img01 {
    position: absolute;
    width: 32vw;
    z-index: 2;
    top: -80px;
    left: 3%;
}

.visit-img02 {
    position: absolute;
    width: 20vw;
    z-index: 3;
    top: 45%;
    right: 3%;
    transform: translateY(-50%);
}

.visit-txt img,
.visit-img01 img,
.visit-img02 img,
.visit-img03 img {
    width: 100%;
}

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

    /* WELCOME */
    .visit {
        width: 100%;
        padding: 140px 0 0;
        /* height: 300px; */
    }

    .visit-inner {
        width: 100%;
        height: 260px;
        background-color: #E9E5DD;
        position: relative;
    }

    .aspect1-1:before {
        content: "";
        display: block;
        padding-top: 28%;
        /* 1:1 */
    }

    .visit-inner::after {
        content: "";
        position: absolute;
        height: 170%;
        width: 100%;
        top: -70%;
        left: 45%;
        /* transform: translateX(-50%); */
        background-image: radial-gradient(rgba(113, 161, 101, 1), rgba(0, 152, 72, 1));
        z-index: 1;
        /* padding-left: 33%; */
        margin-left: 5%;
    }

    .visit-txt {
        position: absolute;
        z-index: 4;
        top: -20vw;
        left: 50%;
        transform: translateX(-50%);
        width: 60vw;
        margin: 3%;
    }

    .bt-visit {
        position: absolute;
        z-index: 5;
        background-color: #075E24;
        width: 280px;
        color: #fff;
        text-align: center;
        border: 1px #fff solid;
        top: 50%;
        left: 50%;
        transform: translateX(-50%);
    }

    .bt-visit a {
        width: 100%;
        height: 100%;
        padding: 20px 0;
        display: block;
    }

    .visit-img01 {
        position: absolute;
        width: max(70vw, 22rem);
        z-index: 2;
        top: min(-87vw, -26rem);
        left: 3%;
    }

    .visit-img02 {
        position: absolute;
        width: 20vw;
        z-index: 3;
        top: 45%;
        right: 3%;
        transform: translateY(-50%);
        display: none;
    }

    .visit-txt img,
    .visit-img01 img,
    .visit-img02 img,
    .visit-img03 img {
        width: 90%;
    }
}

/* movie */
.movie {
    padding: 150px 0;
    background-color: #F3FEEE;
}

.movie-inner {
    width: 70%;
    margin: auto;
    text-align: center;
}

.movie-inner h2 {
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
    font-size: 24px;
    color: #5C4500;
    font-weight: bold;
    margin: 0 0 80px;
    position: relative;
    z-index: 2;
}

.movie-inner h2 span {
    font-family: 'Cinzel', serif;
    font-size: 5.5vw;
    display: block;
    text-align: center;
    color: #5C4500;
    font-weight: normal;
}

.movie-inner h2::before {
    content: "";
    width: 80%;
    height: 17vw;
    background-image: url(../images/movie.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center bottom;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}

.movie-inner>p {
    font-family: zen-old-mincho, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 18px;
    line-height: 1.8;
    width: 75%;
    margin: 0 auto 50px;
    text-align: left;
}

.movie_itemWrap {
    display: flex;
    flex-wrap: wrap;
    gap: 0 10%;
    justify-content: space-between;
}

.movie_itemWrap li {
    width: 45%;
    border-top: 1px solid #7A665B;
    padding-bottom: 40px;
}

.movie_itemWrap li h3 {
    font-family: zen-old-mincho, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 22px;
    text-align: left;
    color: #7A665B;
    padding: 20px 0;
}

.movie_itemWrap li iframe {
    display: block;
    width: 100%;
}

.movie-inner img {
    margin: 50px auto;
    width: 90%;
    max-width: 790px;
}

.movie-inner p.center {
    text-align: center;
    line-height: 2
}

@media screen and (max-width: 896px) {
    .movie {
        padding: 80px 0;
    }

    .movie-inner {
        width: 90%;
    }

    .movie-inner h2 {
        font-size: 16px;
    }

    .movie-inner h2 span {
        font-size: 3em;
    }

    .movie-inner h2::before {
        width: 100%;
        height: 27vw;
        background-position: center top;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -55%);
        z-index: -1;
    }

    .movie_itemWrap {
        flex-direction: column;
        gap: 0;
    }

    .movie_itemWrap li {
        width: 90%;
        margin: 0 auto 20px;
    }

    .movie-inner p.center {
        text-align: center;
        line-height: 2
    }
}

/* Feature */
.feature {
    background: url(../images/feature_bg.png) no-repeat center center / cover;
}

.feature-inner {
    width: 70%;
    margin: auto;
    padding: 100px 0;
}

.feature-inner h2 {
    font-size: 5vw;
    color: #fff;
    text-align: center;
    margin-bottom: 30px;
    font-family: 'Cinzel', serif;
}

.feature-inner span {
    font-size: 1.2em;
    color: #fff;
    text-align: center;
    display: block;
    width: 100%;
    margin-bottom: 80px;
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.feature-box01 {
    width: 100%;
    margin-bottom: 60px;
    display: flex;
}

.feature-box01-inner {
    color: #fff;
    width: 100%;
    line-height: 2;
    margin: 6% -15% 0 0;
    display: flex;
    justify-content: space-between;
    position: relative;
}

.feature_inner-Wrap {
    width: 60%;
}

.feature-box01-inner-l {
    padding: 5% 2% 5% 10%;
    position: relative;
    z-index: 2;
}

.feature-box01-inner-l::before {
    content: "";
    width: 105%;
    height: 100%;
    border: 1px solid #ffffff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.feature-box01-inner-l h3 {
    font-size: 3em;
    font-family: 'Cinzel', serif;
}

.feature-box01-inner-l h4 {
    font-size: 30px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.5;
    margin: 0 0 20px;
}

.feature-box01-inner-l p {
    font-size: 1.4em;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    margin-bottom: 20px;
    line-height: 1.5;
}

.feature .more a {
    width: 300px;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #ffffff;
    color: #657D5A;
    margin: 40px auto;
    font-size: 20px;
}

.feature-box01-inner-r {
    width: 40%;
    position: absolute;
    top: -1px;
    right: -1px;
    z-index: 2;
}

.feature-box01-inner-r img {
    width: 100%;
}

.feature-box02 {
    width: 100%;
    margin-bottom: 60px;
    display: flex;
    justify-content: space-between;
}

.feature-box02-inner {
    color: #fff;
    width: 100%;
    line-height: 2;
    margin: 6% -15% 0 0;
    display: flex;
    justify-content: space-between;
    position: relative;
    flex-direction: row-reverse;
}

.feature-box02-inner-l {
    padding: 5% 2% 5% 10%;
    position: relative;
    z-index: 2;
}

.feature-box02-inner-l::before {
    content: "";
    width: 105%;
    height: 100%;
    border: 1px solid #ffffff;
    position: absolute;
    top: 0;
    left: -5%;
    z-index: 1;
}

.feature-box02-inner-l h3 {
    font-size: 3em;
    font-family: 'Cinzel', serif;
}

.feature-box02-inner-l h4 {
    font-size: 30px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.5;
    margin: 0 0 20px;
}

.feature-box02-inner-l p {
    font-size: 1.4em;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    margin-bottom: 20px;
    line-height: 1.5;
}

.feature-box02-inner-r {
    width: 40%;
    position: absolute;
    top: -1px;
    left: -1px;
    z-index: 2;
}

.feature-box02-inner-r img {
    width: 100%;
}

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

    /* Feature */
    .feature {
        background: url(../images/feature_bg.png) no-repeat center center / cover;
    }

    .feature-inner {
        width: 90%;
        margin: auto;
        padding: 30px 0;
    }

    .feature-inner h2 {
        font-size: 3em;
        color: #fff;
        text-align: center;
        margin-bottom: 30px;
        font-family: 'Cinzel', serif;
    }

    .feature-inner span {
        font-size: 1.2em;
        color: #fff;
        text-align: center;
        display: block;
        width: 100%;
        margin-bottom: 50px;
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .feature-box01 {
        width: 100%;
        margin-bottom: 30px;
        display: flex;
    }

    .feature_inner-Wrap {
        width: 100%;
    }

    .feature-box01-inner {
        border: 1px #fff solid;
        padding: 5%;
        color: #fff;
        width: 100%;
        line-height: 2;
        margin: 6% 0 0 0;
        display: block;
        justify-content: space-between;
        position: initial;
    }

    .feature-box01-inner-l::before {
        display: none;
    }

    .feature-box01-inner-l {
        padding: 5%;
    }

    .feature-box01-inner-l h3 {
        font-size: 2.5rem;
        font-family: 'Cinzel', serif;
    }

    .feature-box01-inner-l p {
        font-size: 1.1em;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        margin-bottom: 20px;
        line-height: 1.5;
    }

    .feature-box01-inner-r {
        width: 100%;
        position: initial;
        top: -5vw;
        right: -12vw;
    }

    .feature-box01-inner-r img {
        width: 100%;
    }

    .feature-box02 {
        width: 100%;
        margin-bottom: 30px;
        display: flex;
        justify-content: center;
    }

    .feature-box02-inner {
        border: 1px #fff solid;
        padding: 5%;
        color: #fff;
        width: 100%;
        line-height: 2;
        margin: 6% 0 0 0;
        display: block;
        justify-content: space-between;
        position: initial;
        flex-direction: row-reverse;
    }

    .feature-box02-inner-l::before {
        display: none;
    }

    .feature-box02-inner-l {
        width: 100%;
        padding: 5%;
    }

    .feature-box02-inner-l h3 {
        font-size: 2.5rem;
        font-family: 'Cinzel', serif;
    }

    .feature-box02-inner-l p {
        font-size: 1.1em;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        line-height: 1.5;
        margin-bottom: 20px;
    }

    .feature-box02-inner-r {
        width: 100%;
        position: initial;
        top: -5vw;
        left: -12vw;
    }

    .feature-box02-inner-r img {
        width: 100%;
    }
}

/* pickup */
.pickup {
    background: url(../images/bg-pickup.png) no-repeat center / cover;
}

.pickup-inner {
    width: 70%;
    margin: auto;
    padding: 100px 0;
}

.pickup-inner h2 {
    font-size: 5vw;
    color: #075E24;
    text-align: center;
    margin-bottom: 10px;
    font-family: 'Cinzel', serif;
}

.pickup-inner>span {
    font-size: 20px;
    color: #075E24;
    text-align: center;
    display: block;
    width: 100%;
    margin-bottom: 150px;
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.pickup-box01 {
    width: 100%;
    margin-bottom: 8vw;
    display: flex;
    justify-content: end;
}

.pickup-box01-inner {
    width: 64%;
    line-height: 2;
    display: flex;
    position: relative;
}

.pickup-box01-inner-l {
    background: rgba(255, 255, 255, .7);
    width: 100%;
    z-index: 1;
    padding: 50px;
}

.pickup-box01-inner-l h3 {
    font-family: zen-old-mincho, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 26px;
}

.pickup-box01-inner-l h3 span {
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 36px;
    color: #075E24;
    margin: 0 30px 0 0;
}

.pickup-box01-inner-l p {
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 16px;
    margin-bottom: 20px;
    line-height: 2;
}

.pickup-box01-inner-r {
    width: 30vw;
    position: absolute;
    top: 5vw;
    left: -25vw;
}

.pickup-box01-inner-r img {
    width: 100%;
}

.pickup-box02 {
    width: 100%;
    margin-bottom: 10vw;
    display: flex;
    justify-content: flex-start;
}

.pickup-box02-inner {
    width: 64%;
    line-height: 2;
    display: flex;
    position: relative;
    flex-direction: row-reverse;
}

.pickup-box02-inner-l {
    background: rgba(255, 255, 255, .7);
    width: 100%;
    z-index: 1;
    padding: 50px;
}

.pickup-box02-inner-l h3 {
    font-family: zen-old-mincho, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 26px;
}

.pickup-box02-inner-l h3 span {
    font-family: yu-mincho-pr6n, sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 36px;
    color: #075E24;
    margin: 0 30px 0 0;
}

.pickup-box02-inner-l p {
    font-size: 1.2em;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.5;
    margin-bottom: 20px;
}

.pickup-box02-inner-r {
    width: 30vw;
    position: absolute;
    top: 5vw;
    right: -25vw;
}

.pickup-box02-inner-r img {
    width: 100%;
}

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

    /* pickup */
    .pickup {
        background: url(../images/bg-pickup.png) no-repeat center / cover;
    }

    .pickup-inner {
        width: 90%;
        margin: auto;
        padding: 70px 0;
    }

    .pickup-inner h2 {
        font-size: 3em;
        color: #075E24;
        text-align: center;
        margin-bottom: 10px;
        font-family: 'Cinzel', serif;
    }

    .pickup-inner>span {
        font-size: 20px;
        color: #075E24;
        text-align: center;
        display: block;
        width: 100%;
        margin-bottom: 80px;
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .pickup-box01 {
        width: 100%;
        margin: 0 0 80px;
        display: flex;
        justify-content: end;
    }

    .pickup-box01-inner {
        width: 100%;
        line-height: 2;
        display: flex;
        position: relative;
    }

    .pickup-box01-inner-l {
        background: rgba(255, 255, 255, .7);
        width: 100%;
        z-index: 1;
        padding: 30px;
    }

    .pickup-box01-inner-l h3 {
        font-family: zen-old-mincho, sans-serif;
        font-weight: 700;
        font-style: normal;
        font-size: 26px;
    }

    .pickup-box01-inner-l h3 span {
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 500;
        font-style: normal;
        font-size: 36px;
        color: #075E24;
        margin: 0 30px 0 0;
        display: block;
    }

    .pickup-box01-inner-l p {
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 500;
        font-style: normal;
        font-size: 16px;
        margin-bottom: 20px;
        line-height: 2;
    }

    .pickup-box01-inner-r {
        display: none;
    }

    .pickup-box01-inner-r img {
        width: 100%;
    }

    .pickup-box02 {
        width: 100%;
        margin-bottom: 10vw;
        display: flex;
        justify-content: flex-start;
    }

    .pickup-box02-inner {
        width: 100%;
        line-height: 2;
        display: flex;
        position: relative;
        flex-direction: row-reverse;
    }

    .pickup-box02-inner-l {
        background: rgba(255, 255, 255, .7);
        width: 100%;
        z-index: 1;
        padding: 50px;
    }

    .pickup-box02-inner-l h3 {
        font-family: zen-old-mincho, sans-serif;
        font-weight: 700;
        font-style: normal;
        font-size: 26px;
    }

    .pickup-box02-inner-l h3 span {
        font-family: yu-mincho-pr6n, sans-serif;
        font-weight: 500;
        font-style: normal;
        font-size: 36px;
        color: #075E24;
        margin: 0 30px 0 0;
        display: block;
    }

    .pickup-box02-inner-l p {
        font-size: 1.2em;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        line-height: 1.5;
        margin-bottom: 20px;
    }

    .pickup-box02-inner-r {
        display: none;
    }

    .pickup-box02-inner-r img {
        width: 100%;
    }
}

/* Medical information */
.medical {
    background: url(../images/medical_bg.png) no-repeat center center / cover;
    padding: 50px 0 100px;
}

.medical-inner {
    width: 70%;
    margin: auto;
}

.m-title-box {
    width: 60%;
    border-bottom: 1px #075E24 solid;
    margin-bottom: 60px;
}

.m-title-box h2 {
    font-size: 3vw;
    color: #075E24;
    padding: 0 0 0 70px;
    font-family: 'Cinzel', serif;
}

.m-title-box span {
    color: #333333;
    font-size: 1vw;
    margin-bottom: 30px;
    display: block;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.m-box {
    display: flex;
    justify-content: space-between;
}

.m-box-1,
.m-box-2,
.m-box-3 {
    width: 30%;
}

.m-box-1 img,
.m-box-2 img,
.m-box-3 img {
    width: 100%;
    margin-bottom: 25px;
}

.m-box h3 {
    padding: 15px 0 15px 60px;
    color: #fff;
    font-size: 1.2vw;
    position: relative;
    margin-bottom: 12px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.m-box-1 h3 {
    background-color: #EC6472;
}

.m-box-2 h3 {
    background-color: #5C4500;
}

.m-box-3 h3 {
    background-color: #4C764F;
}

.m-box-1 h3::after,
.m-box-2 h3::after,
.m-box-3 h3::after {
    position: absolute;
    content: url(../images/icon-tooth.png);
    top: 54%;
    left: 15px;
    transform: translateY(-50%);
}

.m-box-list {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

.m-box-list li {
    width: 50%;
    position: relative;
    display: inline-block;
    padding-left: 25px;
    color: #000;
    text-decoration: none;
    font-size: 1.1vw;
    margin-bottom: 15px;
    font-family: zen-kaku-gothic-new, sans-serif;
    font-weight: 500;
    font-style: normal;
}

.m-box-list li::before {
    content: '';
    width: 12px;
    height: 12px;
    border: 0;
    border-top: solid 2px #5C4500;
    border-right: solid 2px #5C4500;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -7px;
    transform: rotate(45deg);
}

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

    /* Medical information */
    .medical {
        background: url(../images/medical_bg.png) no-repeat center center / cover;
        padding: 50px 0 100px;
    }

    .medical-inner {
        width: 90%;
        margin: auto;
    }

    .m-title-box {
        width: 100%;
        border-bottom: 1px #5C4500 solid;
        margin-bottom: 60px;
    }

    .m-title-box h2 {
        font-size: 3em;
        color: #075E24;
        padding: 0;
        font-family: 'Cinzel', serif;
    }

    .m-title-box span {
        color: #333333;
        font-size: 1em;
        margin-bottom: 30px;
        display: block;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .m-box {
        display: block;
        justify-content: space-between;
    }

    .m-box-1,
    .m-box-2,
    .m-box-3 {
        width: 100%;
    }

    .m-box-1 img,
    .m-box-2 img,
    .m-box-3 img {
        width: 100%;
        margin-bottom: 25px;
    }

    .m-box h3 {
        padding: 15px 0 15px 60px;
        color: #fff;
        font-size: 18px;
        position: relative;
        margin-bottom: 12px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .m-box-1 h3 {
        background-color: #EC6472;
    }

    .m-box-2 h3 {
        background-color: #5C4500;
    }

    .m-box-3 h3 {
        background-color: #4C764F;
    }

    .m-box-1 h3::after,
    .m-box-2 h3::after,
    .m-box-3 h3::after {
        position: absolute;
        content: url(../images/icon-tooth.png);
        top: 54%;
        left: 15px;
        transform: translateY(-50%);
    }

    .m-box-list {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        margin-bottom: 20px;
    }

    .m-box-list li {
        width: 50%;
        position: relative;
        display: inline-block;
        padding-left: 25px;
        color: #000;
        text-decoration: none;
        font-size: 1em;
        margin-bottom: 15px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }

    .m-box-list li::before {
        content: '';
        width: 12px;
        height: 12px;
        border: 0;
        border-top: solid 2px #5C4500;
        border-right: solid 2px #5C4500;
        position: absolute;
        top: 50%;
        left: 0;
        margin-top: -7px;
        transform: rotate(45deg);
    }
}

@media screen and (min-width: 897px) and (max-width:1300px) {

    /* Medical information */
    .medical {
        background: url(../images/medical_bg.png) no-repeat center center / cover;
        padding: 50px 0 100px;
    }

    .medical-inner {
        width: 90%;
        margin: auto;
    }

    .m-title-box {
        width: 50%;
        border-bottom: 1px #5C4500 solid;
        margin-bottom: 60px;
    }

    .m-title-box h2 {
        font-size: 2.5em;
        color: #5C4500;
        padding: 0 0 0 70px;
        font-family: 'Cinzel', serif;
    }

    .m-title-box span {
        color: #333333;
        font-size: 1em;
        margin-bottom: 30px;
        display: block;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .m-box {
        display: flex;
        justify-content: space-between;
    }

    .m-box-1,
    .m-box-2,
    .m-box-3 {
        width: 30%;
    }

    .m-box-1 img,
    .m-box-2 img,
    .m-box-3 img {
        width: 100%;
        margin-bottom: 25px;
    }

    .m-box h3 {
        padding: 15px 0 15px 60px;
        color: #fff;
        font-size: 1.2vw;
        position: relative;
        margin-bottom: 12px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .m-box-1 h3 {
        background-color: #EC6472;
    }

    .m-box-2 h3 {
        background-color: #5C4500;
    }

    .m-box-3 h3 {
        background-color: #4C764F;
    }

    .m-box-1 h3::after,
    .m-box-2 h3::after,
    .m-box-3 h3::after {
        position: absolute;
        content: url(../images/icon-tooth.png);
        top: 54%;
        left: 15px;
        transform: translateY(-50%);
    }

    .m-box-list {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
    }

    .m-box-list li {
        width: 50%;
        position: relative;
        display: inline-block;
        padding-left: 25px;
        color: #000;
        text-decoration: none;
        font-size: 1em;
        margin-bottom: 15px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }

    .m-box-list li::before {
        content: '';
        width: 12px;
        height: 12px;
        border: 0;
        border-top: solid 2px #5C4500;
        border-right: solid 2px #5C4500;
        position: absolute;
        top: 50%;
        left: 0;
        margin-top: -7px;
        transform: rotate(45deg);
    }
}

/* Greeting */
.greeting {
    background: url(../images/greeting_bg.png) no-repeat center center / cover;
    display: flex;
    padding: 100px 0;
}

.greeting-l {
    width: 40%;
}

.greeting-img01 {
    max-width: 700px;
    margin-bottom: 20px;
}

.greeting-img02 {
    max-width: 500px;
    margin-left: auto;
    margin-right: 0;
}

.greeting-img01 img,
.greeting-img02 img {
    width: 100%;
}

.greeting-r {
    width: 60%;
}

.greeting-r-wrap {
    padding: 0 10%;
}

.greeting-r-inner {
    padding: 80px 10%;
    background-color: #fff;
}

.greeting-r h2 {
    color: #5C4500;
    font-size: 4em;
    text-align: center;
    font-family: 'Cinzel', serif;
}

.greeting-r span {
    display: block;
    text-align: center;
    margin-bottom: 50px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.4em;
}

.greeting-r p.c-txt01 {
    font-size: 2.3vw;
    text-align: center;
    line-height: 1.5;
}

.greeting-r p.c-txt01 span {
    font-size: 1.5vw;
    padding-top: 35px;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 700;
    font-style: normal;
    color: #075E24;
}

.greeting-r p.c-txt02 {
    font-size: 1.1em;
    line-height: 2;
    margin-bottom: 80px;
    font-family: zen-kaku-gothic-new, sans-serif;
    font-weight: 500;
    font-style: normal;
}

.g-title {
    position: relative;
    padding-top: 50px;
}

.g-title img {
    position: absolute;
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
}

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

    /* Greeting */
    .greeting {
        background: url(../images/greeting_bg.png) no-repeat center center / cover;
        display: block;
        padding: 100px 0;
    }

    .greeting-l {
        width: 90%;
        margin: 0 auto 20px;
    }

    .greeting-img01 {
        max-width: 700px;
        margin-bottom: 20px;
    }

    .greeting-img02 {
        max-width: 500px;
        margin-left: auto;
        margin-right: 0;
    }

    .greeting-img01 img,
    .greeting-img02 img {
        width: 100%;
    }

    .greeting-r {
        width: 90%;
        margin: auto;
    }

    .greeting-r-wrap {
        padding: 0;
    }

    .greeting-r-inner {
        padding: 80px 0;
        background-color: #fff;
    }

    .greeting-r h2 {
        font-size: 3em;
        text-align: center;
        font-family: 'Cinzel', serif;
    }

    .greeting-r span {
        display: block;
        text-align: center;
        margin-bottom: 0;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 1.4em;
    }

    .greeting-r p.c-txt01 {
        font-size: 2.3vw;
        text-align: center;
        line-height: 1.5;
    }

    .greeting-r p.c-txt01 span {
        font-size: 22px;
        padding-top: 30px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 700;
        font-style: normal;
        color: #075E24;
        padding-bottom: 30px;
    }

    .greeting-r p.c-txt02 {
        font-size: 1em;
        line-height: 2;
        margin-top: 30px;
        margin-bottom: 80px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }

    .g-title {
        position: relative;
        padding-top: 50px;
    }

    .g-title img {
        position: absolute;
        top: -80px;
        left: 50%;
        transform: translateX(-50%);
    }
}

@media screen and (min-width: 897px) and (max-width:1300px) {

    /* Greeting */
    .greeting {
        background: url(../images/greeting_bg.png) no-repeat center center / cover;
        display: flex;
        padding: 100px 0;
    }

    .greeting-l {
        width: 40%;
    }

    .greeting-img01 {
        max-width: 700px;
        margin-bottom: 20px;
    }

    .greeting-img02 {
        max-width: 500px;
        margin-left: auto;
        margin-right: 0;
    }

    .greeting-img01 img,
    .greeting-img02 img {
        width: 100%;
    }

    .greeting-r {
        width: 60%;
    }

    .greeting-r-wrap {
        padding: 0 10%;
    }

    .greeting-r-inner {
        padding: 80px 10%;
        background-color: #fff;
    }

    .greeting-r h2 {
        color: #5C4500;
        font-size: 4em;
        text-align: center;
        font-family: 'Cinzel', serif;
    }

    .greeting-r span {
        display: block;
        text-align: center;
        margin-bottom: 20px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 1.4em;
    }

    .greeting-r p.c-txt01 {
        font-size: 2.3vw;
        text-align: center;
        line-height: 1.5;
    }

    .greeting-r p.c-txt01 span {
        font-size: .9em;
        padding-top: 20px;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 700;
        font-style: normal;
        color: #5C4500;
    }

    .greeting-r p.c-txt02 {
        font-size: 1em;
        line-height: 2;
        margin-bottom: 40px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 500;
        font-style: normal;
    }

    .g-title {
        position: relative;
        padding-top: 50px;
    }

    .g-title img {
        position: absolute;
        top: -70px;
        left: 50%;
        transform: translateX(-25%);
    }
}

/* Recruit */
.recruit {
    padding: 70px 0;
    background-color: #EFF3EA;
}

.recruit-inner {
    border-top: 1px #997F2E solid;
    border-bottom: 1px #997F2E solid;
    padding: 40px 0;
    display: flex;
}

.recruit-inner-l {
    width: 45%;
}

.recruit-inner-r {
    width: 45%;
}

.recruit-inner-r img {
    width: 100%;
}

.recruit-title {
    width: 60%;
    border-bottom: 1px #997F2E solid;
    padding: 50px 0 30px 25%;
    margin-bottom: 50px;
}

.recruit-title h2 {
    font-size: 3em;
    color: #997F2E;
    font-family: 'Cinzel', serif;
}

.recruit-title span {
    font-size: 1em;
    color: #333333;
    font-family: zen-old-mincho, sans-serif;
    font-weight: 400;
    font-style: normal;
}

.recruit-txt {
    padding: 0 0 0 25%;
    font-size: 1.2em;
    margin-bottom: 60px;
    font-family: zen-kaku-gothic-new, sans-serif;
    font-weight: 700;
    font-style: normal;
}

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

    /* Recruit */
    .recruit {
        padding: 70px 0;
    }

    .recruit-inner {
        padding: 40px 0;
        display: flex;
        flex-wrap: wrap;
        flex-direction: column-reverse;
    }

    .recruit-inner-l {
        width: 100%;
    }

    .recruit-inner-r {
        width: 90%;
        margin: auto;
    }
 
    .recruit-inner-r img {
        width: 100%;
    }

    .recruit-title {
        width: 60%;
        padding: 50px 0 30px 5%;
        margin-bottom: 50px;
    }

    .recruit-title h2 {
        font-size: 3.5em;
        padding-left: 0px;
        font-family: 'Cinzel', serif;
    }

    .recruit-title span {
        font-size: 1em;
        color: #333333;
        font-family: zen-old-mincho, sans-serif;
        font-weight: 400;
        font-style: normal;
    }

    .recruit-txt {
        padding: 5%;
        font-size: 1em;
        margin-bottom: 60px;
        font-family: zen-kaku-gothic-new, sans-serif;
        font-weight: 700;
        font-style: normal;
    }
}

.indoor {
    padding: 100px 0;
}

.indoor .indoor_win {
    width: 90%;
    max-width: 800px;
    margin: 0 auto;
}