@charset "utf-8";
:root {
    --cat-bg-color1: #ED6300;
    --cat-bg-color2: #69C118;
    --cat-bg-color3: #13AF43;
    --cat-bg-color4: #EE9E00;
    --section-bg-color1: #FDF4DD;
    --section-bg-color2: #FFF4E4;
}
/*==========================================*/
/*PC & ALL*/
/*==========================================*/
article {
    font-size: 15px;
    font-weight: bold;
    color: var(--main-txt-color);
    line-height: 1.6;
}
/*Title*/
.contents-ttl-block {
    text-align: center;
    position: relative;
}
.contents-ttl-block::after {
    position: absolute;
    content: "";
    width: 200px;
    height: 8px;
    background: url("/kids_yasai/assets/img/common/ico-line01.svg") no-repeat center / contain;
    left: 0;
    right: 0;
    bottom: -24px;
    margin: auto;
}
.contents-ttl img {
    width: auto;
}
.contents-lead .contents-ttl img {
    height: 30px;
}
.contents-hint .contents-ttl img {
    height: 68px;
}
.contents-hint-h3 {
    font-size: 28px;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
}
.contents-hint-h4 {
    width: 330px;
    height: 50px;
    margin: 0 auto;
    background: #C87800;
    border-radius: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.contents-hint-h4 img {
    height: 24px;
    width: auto;
}
.contents-hint-h5 {
    width: 255px;
    margin-inline: auto;
    padding-bottom: 8px;
    border-bottom: 3px dashed #C87800;
    text-align: center;
}
.contents-hint-h5 img {
    height: 22px;
    width: auto;
}
.contents-lead {
    padding-top: 24px;
    padding-bottom: 40px;
    text-align: center;
}
.contents-lead-why {
    padding-top: 64px;
}
.contents-lead-why-list {
    margin-top: 40px;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(4, 150px);
    gap: 16px;
}
.contents-lead-why-list-itm {
    padding-top: 16px;
    padding-bottom: 16px;
    border-radius: 8px;
    font-size: 15px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}
.contents-lead-why-list-itm-ttl img {
    height: 34px;
    width: auto;
}
.contents-lead-why-list-itm-btn {
    width: 130px;
    height: 26px;
    padding-right: .5em;
    font-size: 12px;
    background: #fff;
    border-radius: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}
.contents-lead-why-list-itm-btn::before, .contents-lead-why-list-itm-btn::after {
    position: absolute;
    content: "";
    width: .8em;
    height: 1px;
    background: currentColor;
    top: 0;
    bottom: 0;
    right: .8em;
    margin: auto;
}
.contents-lead-why-list-itm-btn::after {
    transform: rotate(90deg);
}
.contents-lead-why-list-itm.item01 {
    background: var(--cat-bg-color1);
}
.contents-lead-why-list-itm.item02 {
    background: var(--cat-bg-color2);
}
.contents-lead-why-list-itm.item03 {
    background: var(--cat-bg-color3);
}
.contents-lead-why-list-itm.item04 {
    background: var(--cat-bg-color4);
}
.item01 .contents-lead-why-list-itm-btn {
    color: var(--cat-bg-color1);
}
.item02 .contents-lead-why-list-itm-btn {
    color: var(--cat-bg-color2);
}
.item03 .contents-lead-why-list-itm-btn {
    color: var(--cat-bg-color3);
}
.item04 .contents-lead-why-list-itm-btn {
    color: var(--cat-bg-color4);
}
.contents-hint {
    max-width: 700px;
    margin: 0 auto;
}
.full-width {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-left: calc(50vw - 50%);
    padding-right: calc(50vw - 50%);
}
.contents-hint-header {
    padding-top: 40px;
    padding-bottom: 40px;
    background: var(--section-bg-color1);
}
.contents-hint1 {
    padding-top: 56px;
    padding-bottom: 120px;
}
.contents-hint2 {
    padding-top: 56px;
    padding-bottom: 120px;
    background: var(--section-bg-color2);
}
.contents-hint-btn {
    padding-top: 16px;
    padding-bottom: 16px;
}
.contents-note {
    padding-top: 72px;
    padding-bottom: 72px;
    background: var(--section-bg-color1);
}
.contents-assist {
    padding-top: 56px;
    padding-bottom: 40px;
}
.contents-hint-header-anchor {
    margin-top: 40px;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(2, 335px);
    gap: 12px;
}
.contents-hint-header-anchor-link {
    height: 50px;
    padding-left: 24px;
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    background: #C87800;
    border-radius: 8px;
    text-decoration: none;
    display: flex;
    align-items: center;
    position: relative;
}
.contents-hint-header-anchor-link::after {
    position: absolute;
    content: "";
    width: .3em;
    height: .3em;
    border-top: 3px solid currentColor;
    border-left: 3px solid currentColor;
    transform: rotate(-135deg);
    top: 0;
    bottom: 0;
    right: 24px;
    margin: auto;
}
.contents-hint-lead strong, .contents-hint1-txt strong, .contents-hint2-txt strong {
    color: #ff0000;
}
.contents-hint1-wrap {
    margin-top: 40px;
    display: grid;
    gap: 104px;
}
.contents-hint-lead {
    margin-top: 24px;
    text-align: center;
}
.contents-hint1-block__inner {
    margin-top: 16px;
    display: grid;
    gap: 48px;
}
.contents-hint1-block__inner-itm {
    margin-top: 16px;
    display: grid;
    gap: 16px;
}
.contents-hint1-img {
    width: 470px;
    margin: 0 auto;
}
.contents-hint1-img.adjust-width-hint1 {
    width: 340px;
}
.contents-hint2-wrap {
    margin-top: 40px;
    display: grid;
    gap: 48px;
}
.contents-hint2-block {
    display: grid;
    gap: 16px;
}
.contents-hint2-img {
    width: 450px;
    margin: 0 auto;
}
.contents-hint-btn-link {
    width: 560px;
    height: 75px;
    margin: 0 auto;
    padding-left: 24px;
    background: #109037;
    border-radius: 8px;
    display: flex;
    align-items: center;
    position: relative;
}
.contents-hint-btn-link::after {
    position: absolute;
    content: "";
    width: .3em;
    height: .3em;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: rotate(135deg);
    top: 0;
    bottom: 0;
    right: 24px;
    margin: auto;
}
.contents-hint-btn-link img {
    height: 24px;
    width: auto;
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(1%) hue-rotate(230deg) brightness(103%) contrast(102%);
}
.contents-note-block {
    display: flex;
    justify-content: center;
}
.contents-note-img {
    width: 148px;
    flex-shrink: 0;
}
.contents-note-txt {
    width: 438px;
    flex-shrink: 0;
    padding: 20px 24px;
    font-size: 16px;
    background: #fff;
    line-height: 1.5;
    display: grid;
    gap: 4px;
}
.contents-note-txt__name {
    font-size: 22px;
}
.contents-assist-bnr {
    display: grid;
    justify-content: center;
    justify-items: center;
    grid-template-columns: 490px;
    gap: 40px;
}
.contents-assist-bnr-itm-txt {
    margin-bottom: 4px;
    font-size: 16px;
    color: #000;
    text-align: center;
}
.contents-assist-bnr-itm-link {
    display: block;
    border: 1px solid #D5D5D5;
}
.contents-assist-friends {
    padding-top: 120px;
    padding-bottom: 64px;
}
.contents-assist-friends-ttl {
    text-align: center;
    position: relative;
}
.contents-assist-friends-ttl::before {
    position: absolute;
    content: "";
    width: 350px;
    height: 73px;
    background: url("/kids_yasai/assets/img/common/ico-friends03.webp") no-repeat center / contain;
    top: -88px;
    left: 0;
    right: 0;
    margin: auto;
}
.contents-assist-friends-ttl img {
    height: 22px;
    width: auto;
}
.contents-assist-friends-link-wrap {
    margin-top: 24px;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(2, 305px);
    gap: 8px;
}
.contents-assist-friends-link {
    height: 50px;
    padding-left: 24px;
    font-size: 15px;
    font-weight: bold;
    text-decoration: none;
    color: var(--main-txt-color);
    background: #fff;
    border: 3px solid #FFC847;
    border-radius: 30px;
    display: flex;
    align-items: center;
    position: relative;
}
.contents-assist-friends-link::after {
    position: absolute;
    content: "";
    width: .3em;
    height: .3em;
    border-top: 3px solid #FFC847;
    border-left: 3px solid #FFC847;
    transform: rotate(135deg);
    top: 0;
    bottom: 0;
    right: 1em;
    margin: auto;
}
.contents-assist-farm {
    padding-top: 40px;
    border-top: 2px dotted #C8B06F;
    display: grid;
    justify-content: center;
    grid-template-columns: 335px;
}
.contents-assist-farm-itm-txt {
    margin-bottom: 4px;
    font-size: 15px;
    text-align: center;
}
.contents-assist-farm-itm-link {
    display: block;
    border: 1px solid #D5D5D5;
}
/*==========================================*/
/*SP*/
/*==========================================*/
@media screen and (max-width: 768px) {
    article {
        font-size: calc((15 / 375) * 100vw);
    }
    /*Title*/
    .contents-ttl-block::after {
        width: calc((200 / 375) * 100vw);
        height: calc((8 / 375) * 100vw);
        bottom: calc((-24 / 375) * 100vw);
    }
    .contents-ttl img {
        height: calc((68 / 375) * 100vw) !important;
    }
    .contents-hint-h3 {
        font-size: calc((28 / 375) * 100vw);
    }
    .contents-hint-h4 {
        width: calc((330 / 375) * 100vw);
        height: calc((50 / 375) * 100vw);
        border-radius: calc((30 / 375) * 100vw);
    }
    .contents-hint-h4 img {
        height: calc((24 / 375) * 100vw);
    }
    .contents-hint-h5 {
        width: calc((268 / 375) * 100vw);
        padding-bottom: calc((8 / 375) * 100vw);
    }
    .contents-hint-h5 img {
        height: calc((22 / 375) * 100vw);
    }
    .contents-lead {
        width: calc((333 / 375) * 100vw);
        margin: 0 auto;
        padding-top: calc((24 / 375) * 100vw);
        padding-bottom: calc((24 / 375) * 100vw);
        text-align: left;
    }
    .contents-lead-why {
        padding-top: calc((56 / 375) * 100vw);
    }
    .contents-lead-why-list {
        margin-top: calc((40 / 375) * 100vw);
        grid-template-columns: repeat(2, calc((150 / 375) * 100vw));
        gap: calc((16 / 375) * 100vw);
    }
    .contents-lead-why-list-itm {
        padding-top: calc((16 / 375) * 100vw);
        padding-bottom: calc((16 / 375) * 100vw);
        border-radius: calc((8 / 375) * 100vw);
        font-size: calc((15 / 375) * 100vw);
        gap: calc((8 / 375) * 100vw);
    }
    .contents-lead-why-list-itm-ttl img {
        height: calc((34 / 375) * 100vw);
    }
    .contents-lead-why-list-itm-btn {
        width: calc((130 / 375) * 100vw);
        height: calc((26 / 375) * 100vw);
        font-size: calc((12 / 375) * 100vw);
        border-radius: calc((30 / 375) * 100vw);
    }
    .contents-hint {
        max-width: calc((335 / 375) * 100vw);
    }
    .contents-hint-header {
        padding-top: calc((40 / 375) * 100vw);
        padding-bottom: calc((40 / 375) * 100vw);
    }
    .contents-hint1 {
        padding-top: calc((32 / 375) * 100vw);
        padding-bottom: calc((64 / 375) * 100vw);
    }
    .contents-hint2 {
        padding-top: calc((32 / 375) * 100vw);
        padding-bottom: calc((64 / 375) * 100vw);
    }
    .contents-hint-btn {
        padding-top: calc((16 / 375) * 100vw);
        padding-bottom: calc((16 / 375) * 100vw);
    }
    .contents-note {
        padding-top: calc((40 / 375) * 100vw);
        padding-bottom: calc((40 / 375) * 100vw);
    }
    .contents-assist {
        padding-top: calc((40 / 375) * 100vw);
        padding-bottom: calc((40 / 375) * 100vw);
    }
    .contents-hint-header-anchor {
        margin-top: calc((64 / 375) * 100vw);
        grid-template-columns: calc((335 / 375) * 100vw);
        gap: calc((12 / 375) * 100vw);
    }
    .contents-hint-header-anchor-link {
        height: calc((50 / 375) * 100vw);
        padding-left: calc((24 / 375) * 100vw);
        font-size: calc((20 / 375) * 100vw);
        border-radius: calc((8 / 375) * 100vw);
    }
    .contents-hint-header-anchor-link::after {
        right: calc((24 / 375) * 100vw);
    }
    .contents-hint1-wrap {
        margin-top: calc((24 / 375) * 100vw);
        gap: calc((64 / 375) * 100vw);
    }
    .contents-hint-lead {
        margin-top: calc((24 / 375) * 100vw);
        text-align: left;
    }
    .contents-hint1-block__inner {
        margin-top: calc((16 / 375) * 100vw);
        gap: calc((32 / 375) * 100vw);
    }
    .contents-hint1-block__inner-itm {
        margin-top: calc((16 / 375) * 100vw);
        gap: calc((16 / 375) * 100vw);
    }
    .contents-hint1-img {
        width: 100% !important;
    }
    .contents-hint2-wrap {
        margin-top: calc((24 / 375) * 100vw);
        gap: calc((32 / 375) * 100vw);
    }
    .contents-hint2-block {
        gap: calc((16 / 375) * 100vw);
    }
    .contents-hint2-img {
        width: 100%;
    }
    .contents-hint-btn-link {
        width: calc((344 / 375) * 100vw);
        height: calc((102 / 375) * 100vw);
        padding-left: calc((16 / 375) * 100vw);
        border-radius: calc((8 / 375) * 100vw);
    }
    .contents-hint-btn-link::after {
        right: calc((16 / 375) * 100vw);
    }
    .contents-hint-btn-link img {
        height: calc((50 / 375) * 100vw);
    }
    .contents-note-block {
        gap: calc((16 / 375) * 100vw);
    }
    .contents-note-img {
        width: calc((120 / 375) * 100vw);
    }
    .contents-note-txt {
        width: calc((206 / 375) * 100vw);
        padding: 0;
        font-size: calc((14 / 375) * 100vw);
        background: none;
        gap: calc((4 / 375) * 100vw);
    }
    .contents-note-txt__name {
        font-size: calc((18 / 375) * 100vw);
    }
    .contents-assist-bnr {
        padding-inline: 0;
        grid-template-columns: 100%;
        gap: calc((32 / 375) * 100vw);
    }
    .contents-assist-bnr-itm-txt {
        margin-bottom: calc((4 / 375) * 100vw);
        font-size: calc((16 / 375) * 100vw);
        letter-spacing: 0;
    }
    .contents-assist-bnr-itm:nth-child(1) {
        width: calc((320 / 375) * 100vw);
    }
    .contents-assist-bnr-itm:nth-child(2) .contents-assist-bnr-itm-link {
        display: block;
        width: calc((320 / 375) * 100vw);
        margin: 0 auto;
    }
    .contents-assist-friends {
        padding-top: calc((104 / 375) * 100vw);
        padding-bottom: calc((40 / 375) * 100vw);
    }
    .contents-assist-friends-ttl::before {
        width: calc((350 / 375) * 100vw);
        height: calc((73 / 375) * 100vw);
        top: calc((-88 / 375) * 100vw);
    }
    .contents-assist-friends-ttl img {
        height: calc((20 / 375) * 100vw);
    }
    .contents-assist-friends-link-wrap {
        margin-top: calc((16 / 375) * 100vw);
        grid-template-columns: calc((305 / 375) * 100vw);
        gap: calc((8 / 375) * 100vw);
    }
    .contents-assist-friends-link {
        height: calc((50 / 375) * 100vw);
        padding-left: calc((24 / 375) * 100vw);
        font-size: calc((15 / 375) * 100vw);
        border-radius: calc((30 / 375) * 100vw);
    }
    .contents-assist-farm {
        padding-top: calc((40 / 375) * 100vw);
        grid-template-columns: calc((335 / 375) * 100vw);
    }
    .contents-assist-farm-itm-txt {
        margin-bottom: calc((4 / 375) * 100vw);
        font-size: calc((15 / 375) * 100vw);
    }
}
/*モーダル表示*/
.modal-content {
    width: 480px;
    box-shadow: 0 0 10px rgb(0 0 0 / .1);
    position: relative;
}
.modal-content-block {
    padding: 56px 16px 20px;
}
#modal1 .modal-content-block {
    background: var(--cat-bg-color1);
}
#modal2 .modal-content-block {
    background: var(--cat-bg-color2);
}
#modal3 .modal-content-block {
    background: var(--cat-bg-color3);
}
#modal4 .modal-content-block {
    background: var(--cat-bg-color4);
}
.modal-content-inner {
    padding: 32px;
    font-size: 16px;
    font-weight: bold;
    background: #fff;
    border-radius: 8px;
    line-height: 1.8;
}
.modal-content-ttl {
    font-size: 24px;
    text-align: center;
}
.modal-content-note {
    margin-top: 24px;
    display: grid;
    gap: 1em;
}
.modal-content-note strong {
    color: #FF0000;
}
.modal-close {
    position: absolute;
    display: block;
    width: 28px;
    top: 12px;
    right: 10px;
    cursor: pointer;
}
@media screen and (max-width: 768px) {
    .modal-content {
        width: 100vw;
    }
    .modal-content-block {
        max-height: 85vh;
        padding: calc((56 / 375) * 100vw) calc((16 / 375) * 100vw) calc((20 / 375) * 100vw);
        overflow-y: scroll;
    }
    .modal-content-inner {
        padding: calc((32 / 375) * 100vw);
        font-size: calc((16 / 375) * 100vw);
        border-radius: calc((8 / 375) * 100vw);
    }
    .modal-content-ttl {
        font-size: calc((24 / 375) * 100vw);
    }
    .modal-content-note {
        margin-top: calc((24 / 375) * 100vw);
    }
    .modal-close {
        width: calc((28 / 375) * 100vw);
        top: calc((12 / 375) * 100vw);
        right: calc((10 / 375) * 100vw);
    }
}