html,
body {
    font-size: 10px;
}

li {
    list-style: none;
}

body {
    background: none;
    color: #333;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1.5;
}

.wrapper {
    background-color: #e5f3df;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2);
    margin: 0 auto;
    max-width: 1280px;
    padding-bottom: 5rem;
    width: 1280px;
}

.section-interview {
    background-color: #009380;
    border-radius: 94px 94px 0 0;
    color: #ffff;
    margin-top: 27.3rem;
    padding: 8rem 0 11.2rem;
    position: relative;
}

.section-interview::before {
    background: url(../img/deco-section-interview_pc.svg) no-repeat center / contain;
    content: "";
    display: block;
    height: 124px;
    left: 0;
    position: absolute;
    top: 13px;
    transform: translate(80px, -100%);
    width: 697px;
}

.section-ttl {
    color: #fff;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 32px;
    line-height: 1.5;
    margin: 0 auto;
    position: relative;
    text-align: center;
    width: fit-content;
}

.section-ttl::after {
    content: "";
    display: block;
    height: 5px;
    background-image: radial-gradient(circle, #fff 1px, transparent 2px);
    background-size: 10px 5px;
    background-repeat: repeat-x;
    margin-top: .75rem;
    width: 98%;
}

.img-ctr {
    margin: 12rem auto;
    position: relative;
    text-align: center;
}

.app-img {
    width: 800px;
}

.img-ctr.app::before {
    background: url(../img/deco_application_animal_pc.png) no-repeat 0 0 / contain;
    bottom: -10%;
    content: "";
    position: absolute;
    height: 236px;
    left: 10%;
    width: 218px;
}

.prof-img {
    width: 792px;
}

.img-ctr.prof::after {
    background: url(../img/deco_animal_comment_pc.png) no-repeat 0 0 / contain;
    bottom: -24%;
    content: "";
    position: absolute;
    height: 274px;
    right: 3%;
    width: 276px;
}

.overview-list {
    margin: auto;
    width: 100%;
}

.overview-item {
    display: grid;
    gap: 0 5.3rem;
    grid-template-columns: 370px 1fr;
    margin: auto;
    padding: 12rem 0 8rem;
    position: relative;
    width: 920px
}

.overview-item::before {
    background: #fff;
    content: "";
    height: 1px;
    left: 50%;
    position: absolute;
    top: 0;
    transform: translateX(-50%);
    width: 1120px;
}

.overview-item:last-child::after {
    background: #fff;
    bottom: 0;
    content: "";
    height: 1px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 1120px;
}

.overview-ttl {
    font-size: 2.8rem;
    font-weight: 600;
    letter-spacing: .05em;
    line-height: 1.8;
}

.overview-txt {
    font-size: 1.7rem;
    font-weight: 400;
    letter-spacing: .05em;
    line-height: 2;
}

.overview-img-ctr {
    display: flex;
    grid-column: 1 / -1;
    justify-content: space-between;
    margin: 4rem auto 1rem;
    width: 100%;
}

.sample-img {
    width: 433px;
}

.annotation-txt {
    font-size: 1.4rem;
    font-weight: normal;
    grid-column: 1 / -1;
    text-align: right;
}

.section-txt {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 2;
    margin: 12rem auto 22rem;
    text-align: center;
    width: 514px;
}

.course-item-link {
    align-items: center;
    background-color: #000;
    color: #fff;
    border-radius: 200px;
    display: flex;
    font-size: 2.7rem;
    font-weight: 500;
    height: 80px;
    justify-content: center;
    letter-spacing: .075em;
    margin: 22rem auto 0;
    padding: 0 .2rem 0 0;
    position: relative;
    width: 357px;
}

.course-item-link::after {
    background-color: #fff;
    content: "";
    display: block;
    height: 47px;
    margin-left: 1.5rem;
    /* SVGをマスクとして設定 */
    -webkit-mask: url(../img/deco_coursearrow_pc.svg) no-repeat center / contain;
    mask: url(../img/deco_coursearrow_pc.svg) no-repeat center / contain;
    width: 76px;
}

.section-contact {
    display: flex;
    justify-content: space-between;
    margin: auto;
    padding: 16.2rem 0 10rem;
    width: 1124px;
}

.contactarea-ctr {
    color: #fff;
    display: grid;
    gap: 3rem;
    height: 355px;
    letter-spacing: .075em;
    place-content: center;
    place-items: center;
    width: 550px;
}

.contactarea-ctr.inquiry {
    background: url(../img/deco_contact_bg_pc.png) no-repeat 0 0 /contain;

}

.contactarea-ctr.join {
    background: url(../img/deco_join_bg_pc.png) no-repeat 0 0 /contain;
}

.contactarea-ttl {
    font-size: 2.6rem;
    font-weight: bold;
    margin: 3rem auto 0 0;
}

.contactarea-txt {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.8;
}

.contactarea-link {
    background: #000;
    border: none;
    bottom: -20px;
    border-radius: 100px;
    cursor: pointer;
    height: 34px;
    position: relative;
    transform: translate(100%, 50%);
    width: 54px;
    right: -140px;
}

.contactarea-link::before {
    border-top: 3px solid #fff;
    border-radius: 2px;
    border-right: 3px solid #fff;
    content: "";
    height: 12px;
    left: 48%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
    width: 12px;
}

.custom-footer .general-footer-inner {
    max-width: 1100px;
}

.general-footer-group {
    width: 40%;
}

.general-footer-group {
    display: grid;
    gap: 2rem 0;
}

.copyright {
    color: #000;
}