/* btn-list
------------------------- */

h2.btn-list-ttl {
    margin: 10%;
}



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

.hd-btn a {
    color: #fff;
    background: var(--main-color);
    font-size: 16px !important;;
    font-weight: bold;
    display: flex !important;;
    align-items: center !important;;
    justify-content: center !important;;
    width: 148px !important;;
    text-align: center;
    padding-right: 20px !important;;
    border-radius: 32px;
    position: relative;
}

.hd-btn a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 2em;
    height: 2em;
    background: url("../img/icon-arrow02.svg") no-repeat center / contain;
    transform: translateY(-50%);
    transition: transform .3s ease;
}

.hd-btn a:hover::after {
    transform: translate(4px, -50%);
}



@media only screen and (max-width: 1024px) {
    .hd-btn {
        display: none;
    }
}



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

.fv0002-btn {
    color: #fff;
    background: var(--main-color);
    border-radius: 10px;
    font-size: 16px;
    padding: 1em 0;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 280px;
    text-align: center;
    position: relative;
}

.fv0002-btn::before {
    position: absolute;
    content: "";
    right: 30px;
    width: 6px;
    height: 6px;
    border-top: 1.5px solid #fff;
    border-right: 1.5px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.fv0002-btn:hover {
    background: #ccc;
    opacity: 1;
}

@media (max-width: 767px) {

    .fv0002-btn {
        border-radius: 8px;
    }
}

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

.more-link {
    position: relative;
    text-decoration: underline;
    padding-right: 1em;
    font-weight: bold;
}

.more-link::before {
    position: absolute;
    content: "";
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 8px;
    height: 8px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.more-link-wrap {
    margin-top: 1em;
}




.news-btn {
    color: #251E1C;
    border-radius: 4px;
    padding: .7em 0;
    font-weight: bold;
    display: flex;
    width: 148px;
    text-align: center;
    align-items: center;
    justify-content: center;
    margin-left: auto;
}

.news-btn i {
    font-size: 12px;
    padding-left: .7em;
}

@media (max-width: 767px) {
    .news-btn {
        justify-content: flex-end;
    }
}







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

.contact-btn {
    color: #111;
    border: solid 2px #111;
    border-radius: 10px;
    padding: 1.2em;
    font-weight: bold;
    display: inline-block;
    width: 280px;
    text-align: center;
}

.contact-btn i {
    padding-left: 1em;
    font-size: 14px;
}

.contact-btn:hover {
    border: solid 2px #707070;
    color: #707070;
    opacity: 1;
}

@media only screen and (max-width: 767px) {}


.co0003-btnwrap {
    margin-top: 32px;
}

.co0003-btn {
    font-weight: bold;
    border-radius: 10px;
    width: 260px;
    display: inline-block;
    padding: 1em;
    background: #DEDEDE;
    text-align: center;

}

.co0004-arrowrap {
    text-align: right;
}

.co0004-btn:hover {
    transform: translate(50px, 0);
}

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

.po0001-arrowrap {
    margin-top: 16px;
}

.po0001-arrowrap .arrow-m {
    margin-left: .7em;
    margin-bottom: .7em;

}

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

.home-btn-wrap {
    margin-top: 40px;
}

@media screen and (max-width: 767px) {
    .home-btn-wrap {
        margin-top: 24px;
    }
}

.home-btn {
    position: relative;
    display: flex;
    margin: auto;
    padding: .5em;
    padding-left: 2em;
    max-width: 190px;
    background: #fff;
    border: solid 2px var(--main-color);
    color: var(--main-color);
    border-radius: 32px;

}

@media screen and (max-width: 767px) {
    .home-btn {
        max-width: 180px;
    }
}

.home-btn.is-right {
    margin-left: auto;
}

.home-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 16px;
    width: 2em;
    height: 2em;
    background: url("../img/icon-arrow01.svg") no-repeat center / contain;
    transform: translateY(-50%);
    transition: transform .3s ease;
}

.home-btn:hover::after {
    transform: translate(4px, -50%);
}

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

.more-btn-wrap {
    margin-top: 40px;
}

@media screen and (max-width: 767px) {
    .more-btn-wrap {
        margin-top: 24px;
    }
}

.more-btn {
    position: relative;
    display: flex;
    padding: 1em;
    padding-left: 2em;
    max-width: 220px;
    background: #fff;
    border: solid 2px var(--main-color);
    color: var(--main-color);
    border-radius: 32px;

}

@media screen and (max-width: 767px) {
    .more-btn {
        max-width: 180px;
    }
}

.more-btn.is-right {
    margin-left: auto;
}

@media screen and (max-width: 767px) {
.more-btn.is-right {
    margin: auto;
}
}

.more-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 16px;
    width: 2em;
    height: 2em;
    background: url("../img/icon-arrow01.svg") no-repeat center / contain;
    transform: translateY(-50%);
    transition: transform .3s ease;
}

.more-btn:hover::after {
    transform: translate(4px, -50%);
}
/* 
------------------------- */



.btn-archive-wrap {
    /* margin-top: 40px; */
}

@media screen and (max-width: 767px) {
    .btn-archive-wrap {
        margin-bottom: 24px;
    }
}

.btn-archive {
    position: relative;
    display: flex;
    margin: auto;
    padding: 1em;
    padding-left: 4em;
    max-width: 220px;
    background: #fff;
    border: solid 2px var(--main-color);
    color: var(--main-color);
    border-radius: 32px;

}

/* @media screen and (max-width: 767px) {
    .btn-archive {
        max-width: 180px;
    }
} */

.btn-archive::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 16px;
    width: 2em;
    height: 2em;
    background: url("../img/icon-arrow01.svg") no-repeat center / contain;
    transform: translateY(-50%) rotate(180deg); 
    transition: transform .3s ease;

}

.btn-archive:hover::after {
    transform: translate(4px, -50%);
}

/* 
------------------------- */
.c-contact {
    font-weight: bold;
    font-size: 20px;
    display: flex;
    align-items: center;
    border-radius: 62px;
    width: 100%;
    max-width: 320px;
    padding: .7em 2em;
}

.c-contact-btn {
    color: #fff;
    background: var(--main-color);
}

.c-contact-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 1.2em;
    height: 1.2em;
    background: url("../img/icon-arrow02.svg") no-repeat center / contain;
    transform: translateY(-50%);
    transition: transform .3s ease;
}

.c-line-btn {
    background: #fff;
    border: solid 2px var(--line-color);
}

.c-line-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 1.2em;
    height: 1.2em;
    background: url("../img/icon-arrow03.svg") no-repeat center / contain;
    transform: translateY(-50%);
    transition: transform .3s ease;
}


.c-contact:hover::after {
    transform: translate(4px, -50%);
}

.fv-btn {
    max-width: 300px;
}


@media (max-width: 1024px) {
    .c-contact {
        font-size: 16px;
        margin: auto;
        margin-top: 1em;
        max-width: 260px;
    }

    .fv-btn {
        max-width: 240px;
        margin: 0;
    }

}


.icon-contact {
    margin-right: 15px;
    width: 32px;
}



@media (max-width: 1024px) {

    .icon-contact {
        width: 20px;
    }


}

.c-contact {
    position: relative;
}


/* 404page
------------------------- */

.error-page-btn {
    color: var(--main-color);
    background: var(--main-color);
    color: #fff;
    border-radius: 10px;
    padding: 1.2em;
    font-weight: bold;
    display: inline-block;
    width: 280px;
    text-align: center;
}

.error-page-btn:hover {
    background: #ccc;
    opacity: 1;
}



.po0008-btnwrap {
    /* margin-top: 10%; */
    text-align: right;
}

.po0008-btn {
    display: inline-block;
    text-align: center;
    text-decoration: underline #ccc;
    line-height: 2;
    width: 260px;
    position: relative;
    background-image: url(../img/arrow-gray.svg);
    background-repeat: no-repeat;
    background-position: 90%;
    font-weight: bold;
}

.po0008-btn:hover {
    opacity: 1;
    text-decoration: underline #000;
    background-position: 100%;
}











/* ページトップへ戻るボタン 
--------------------------------------------------------------*/

#pagetop {
    position: fixed;
    z-index: 9;
    bottom: 13px;
    right: 5px;
}


#pagetop a:hover {
    opacity: 0.7;
    text-decoration: none;
}




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

    #pagetop {
        bottom: -1000px;
    }
}






/* pt0004 
-------------------------------- */

.pt0004 .button {
    margin: 10px;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: var(--accent-color);
    border-radius: 50%;
    cursor: pointer;
    font-size: 26px;
    text-align: center;
}

.pt0004 .button:hover {
    opacity: .7;
}