.main_contents {
    display: flex;
    flex-direction: column;
    gap: 30px 0;
}

.main_contents .sec_bg {
    background-color: #9d957d;
    padding: 30px 0;
}

.sec_inner {
    max-width: 1054px;
    width: 90%;
    margin: 0 auto;
}

.sec_ttl {
    text-align: center;
    font-size: clamp(21px,2.5vw,27px);
}

.sec_lead {
    text-align: center;
    font-size: clamp(17px,2vw,22px);
    margin-top: 10px;
}

.sec_bg .sec_ttl,
.sec_bg .sec_lead {
    color: #fff;
}


/* SPのみ */
@media screen and (max-width:730px) {
    .page_ttl {
        margin-bottom: -30%;
    }

    .main_contents {
        gap: 20px 0;
    }

    .bottom_note {
        margin: 35px auto 80px;
    }
}


.sec01 .sec_bg {
    padding-bottom: 50px;
}

.sec01 .img01 {
    margin: 30px 0 40px;
}

.sec01 .container {
    display: grid;
    grid-template-columns: 50% 1fr;
    gap: 0 5%;
}

.sec01 .box_ttl {
    color: #fff;
    font-size: clamp(18px,2vw,24px);
}

.sec01 .box_lead {
    color: #fff;
    font-size: clamp(17px,2vw,20px);
    margin: 10px 0;
}

.sec01 .box_txt {
    color: #fff;
    font-size: clamp(13px,1.4vw,15px);
    line-height: 1.7;
}


.sec01 .box01 .image {
    max-width: 250px;
    margin-bottom: 10px;
}

.sec01 .box02 {
    background-color: #706856;
    padding: 20px 20px 25px;
    display: grid;
    grid-template-columns: 51% 1fr;
    gap: 0 4%;
    align-self: flex-end;
}

.sec01 .box02 .image {
    grid-column: 1;
    grid-row: 1/4;
}

.sec01 .box02 .box_ttl {
    margin: 0 0 10px;
}

.sec01 .box02 .name_small {
    color: #fff;
    font-size: clamp(11px,1.3vw,14px);
}

.sec01 .box02 .name {
    color: #fff;
    font-size: clamp(24px,2.8vw,30px);
}

.sec01 .box02 .box_txt {
    margin-top: 15px;
    grid-column: 1/3;
}

/* SPのみ */
@media screen and (max-width:730px) {
    .sec01 .sec_bg {
        padding: 30% 0 30px;
    }

    .sec01 .img01 {
        margin: 30px -5.5%;
    }

    .sec01 .container {
        display: flex;
        flex-direction: column;
        gap: 30px 0;
    }

    .sec01 .box01 .image {
        width: 60%;
        margin: 0 auto 10px;
    }

    .sec01 .box01 .box_ttl {
        text-align: center;
    }

    .sec01 .box01 .box_lead {
        text-align: center;
    }

    .sec01 .box02 {
        padding: 20px;
    }
}

.sec02 .img01 {
    margin-top: 20px;
}

/* SPのみ */
@media screen and (max-width:730px) {

    .sec02 .sec_bg {
        padding: 20px 0 0;
    }

    .sec02 .img01 {
        margin: 20px -5.5% 0;   
    }
}


.sec06 .img01 {
    margin-top: 20px;
}

/* SPのみ */
@media screen and (max-width:730px) {

    .sec06 .sec_bg {
        padding: 20px 0 0;
    }

    .sec06 .img01 {
        margin: 20px -5.5% 0;
    }
}




.sec03 .sec_bg {
    padding-bottom: 50px;
}

.sec03 .sec_ttl {
    margin: 5px 0 0;
}

.sec03 .sec_ttl_ja {
    color: #fff;
    text-align: center;
    font-size: clamp(13px,1.4vw,16px);
}

.sec03 .sec_ttl_ja02 {
    letter-spacing: 0.1em;
}

.sec03 .sec_txt {
    color: #fff;
    text-align: center;
    font-size: clamp(14px,1.5vw,17px);
    line-height: 1.7;
    margin: 20px 0 30px;
}



.sec_sticky {
    margin: 40px auto 0;
    display: flex;
    justify-content: space-between;
}

.sec_sticky_map {
    width: 50%;
    position: sticky;
    top: 20vh;
    z-index: 1;
    align-self: flex-start;
}

.sec_sticky_map .image {
    display: block;
    max-width: 600px;
    margin: 0 0 0 auto;
}

.sec_sticky .container {
    background-color: #e6e6e6;
    padding: 30px;
}

.sec_sticky .container {
    width: 45%;
    display: flex;
    flex-direction: column;
    gap: 50px 0;
}

.sec_sticky .box_ttl {
    color: #4d4d4d;
    font-size: clamp(17px,2vw,20px);
    display: flex;
    gap: 0 0.3em;
}

.sec_sticky .box_ttl .no {
    background-color: #231815;
    color: #fff;
    padding: 0 0.5em 0.1em;
    font-size: 0.8em;
    margin-top: 0.2em;
    align-self: flex-start;
}

.sec_sticky .box_txt {
    font-size: clamp(13px,1.4vw,15px);
    line-height: 1.6;
    margin-top: 10px;
}

.sec_sticky .box .image {
    margin-top: 15px;
}


/* SPのみ */
@media screen and (max-width:730px) {
    .sec_sticky {
        position: relative;
        z-index: 1003;
        width: 111%;
        margin: 15px -5.5% 0;
        flex-direction: column;
    }

    .sec_sticky_map {
        width: 100%;
        top: 0;
        padding: 10px 0;
        background-color: #9d957d;
    }

    .sec_sticky_map img {
        display: block;
        width: 70%;
        margin: 0 auto;
        padding-bottom: 10px;
    }

    .sec_sticky .container {
        width: 100%;
    }
}


.sec04 {
    margin: 50px 0;
}

.sec04 .sec_lead {
    margin-top: 0;
}

.sec04 .container {
    display: grid;
    grid-template-columns: 57% 1fr;
    gap: 0 2%;
    margin-top: 20px;
}

.sec04 .sec_txt {
    grid-column: 2;
    font-size: clamp(13px, 1.4vw, 15px);
    line-height: 1.7;
}

.sec04 .img01 {
    grid-column: 1;
    grid-row: 1/3;
}

.sec04 ul {
    display: flex;
    flex-direction: column;
    gap: 10px 0;
    margin-top: 20px;
}

.sec04 ul li .lead {
    color: #a18b58;
    font-size: clamp(15px,1.5vw,16px);
}

.sec04 ul li .bg {
    background-color: #f6f5ee;
    border: 1px solid #9d9d9e;
    padding: 8px 5px;
    display: flex;
    gap: 0 0.3em;
    margin-top: 5px;
    font-size: clamp(14px,1.4vw,14px);
}

.sec04 ul li .bg .no {
    background-color: #00484e;
    color: #fff;
    border-radius: 50%;
    width: 1.5em;
    height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 0.1em;
    flex-shrink: 0;
}


/* SPのみ */
@media screen and (max-width:730px) {
    .sec04 {
        margin: 20px 0 30px;
    }
    
    .sec04 .container {
        display: flex;
        flex-direction: column;
        margin-top: 10px;
    }

    .sec04 .img01 {
        margin-top: 15px;
    }

    .sec04 ul {
        margin-top: 15px;
    }
}


.sec05 .sec_lead {
    margin-top: 0;
}
.sec05 .sec_txt {
    text-align: center;
    font-size: clamp(14px, 1.5vw, 17px);
    line-height: 1.7;
    margin: 20px 0 30px;
}

.sec05 .container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 3%;
    align-items: center;
}

/* SPのみ */
@media screen and (max-width:730px) {
    .sec05 .sec_txt {
        margin-bottom: 25px;
    }

    .sec05 .container {
        display: flex;
        flex-direction: column;
        gap: 20px 0;
    }
}