@charset "UTF-8";
/*---------------------------------
  Utility
---------------------------------*/
.u-sp {
  display: block;
}

.u-tab {
  display: none;
}

.u-pc {
    display: none;
}

@media (min-width: 768px) {
    .u-sp {
        display: none;
    }

    .u-tab {
        display: block;
    }
}

@media (min-width: 1024px) {
    .u-pc {
        display: block;
    }
}

/*---------------------------------
  Layout
---------------------------------*/
.wrapper img {
    max-width: 100%;
    height: auto;
}

.l-inner {
    max-width: 1040px;
	padding-inline: 20px;
    margin-inline: auto;
	position: relative;
	z-index: 1;
    box-sizing: border-box;
}

/*---------------------------------
  mv
---------------------------------*/
.mv {
    padding-block: 100px 60px;
    position: relative;
}

.mv__bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.mv__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mv__sub__text {
    background-color: #F37F28;
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    padding: 8px 8px 8px 0;
    position: absolute;
    left: 20px;
    top: -100px;
}

.mv__sub__text::before,
.mv__sub__text::after {
    content: "";
    position: absolute;
    height: 100%;
    top: 0;
    background-color: #F37F28;
}

.mv__sub__text::before {
    width: 100%;
    left: -100%;
}

.mv__sub__text::after {
    width: 20px;
    right: -20px;
    clip-path: polygon(0 0, 100% 0, 50% 100%, 0% 100%);

}

.mv__hdg__lv1 {
    font-weight: 900;
    display: flex;
    flex-direction: column;
    -webkit-text-stroke: 6px #fff;
    paint-order: stroke fill;
}

.mv__hdg__lv1 > .sub {
    font-size: 28px;
}

.mv__hdg__lv1 > .main {
    font-size: 28px;
    display: flex;
    flex-direction: column;
}

.mv__hdg__lv1 > .main > .row {
    background: linear-gradient(transparent 70%, #FFE800 0);
    width: fit-content;
}

.mv__hdg__lv1 > .main .large {
    font-size: 40px;
}

.mv__hdg__lv1 > .main ._orange {
    color: #F37F28;
}

.mv__hdg__lv1 > .main ._blue {
    color: #3A5BD1;
}

.mv__column {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.mv__item {
    flex: 1;
}

.mv__lead {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-feature-settings: "palt";
}

.mv__lead > .text {
    width: fit-content;
    background-color: #fff;
    font-size: 16px;
    font-weight: 700;
    padding: 4px 8px;

}


.mv__image01 {
    margin-top: 24px;
    display: flex;
    justify-content: center;
    gap: 16px;
}

.mv__image01 > li {
    flex: 1;
}

.mv__button {
    margin-top: 24px;

}

.button__01 {
    display: flex;
    align-items: center;
    height: 64px;
    position: relative;
    border-bottom: 4px solid #F37F28;
    background-color: #fff;
    border-radius: 5px;
    transition: .4s;
}

.button__01 > .text {
    font-size: 22px;
    font-weight: 700;
    padding-left: 68px;
    color: #F37F28;
    transition: .4s;
}

.button__01 > .download_icon,
.button__01 > .contact_icon {
    position: absolute;
    left: 20px;
    top: 50%;
    translate: 0 -50%;
    width: 35px;
}

.button__01 > .button_arrow {
    position: absolute;
    right: 20px;
    top: 50%;
    translate: 0 -50%;
    width: 14px;
    line-height: 1;
}

@media (min-width: 768px) {
    .mv__hdg__lv1 > .main {
        flex-direction: row;
    }

    .mv__column {
        flex-direction: row;
    }

    .mv__button {
        max-width: 460px;
        margin-left: auto;
    }
}

@media (min-width: 1024px) {
    .mv {
        padding-block: 112px 65px;
    }

    .mv__sub__text {
        font-size: 32px;
        padding: 16px 16px 16px 0;
        top: -112px;
    }

    .mv__sub__text::after {
        width: 80px;
        right: -80px;
    }

    .mv__hdg__lv1 {
        -webkit-text-stroke: 12px #fff;
    }

    .mv__hdg__lv1 > .sub {
        font-size: 64px;
    }

    .mv__hdg__lv1 > .main {
        font-size: 64px;
    }

    .mv__hdg__lv1 > .main .large {
        font-size: 82px;
    }


    .mv__column {
        margin-top: 34px;
    }

    .mv__lead {
        gap: 16px;
    }

    .mv__lead > .text {
        font-size: 24px;
        padding: 8px 16px;
    }

    .mv__image01 {
        margin-top: 34px;
        gap: 32px;
    }

    .mv__button {
        margin-top: 32px;

    }

    .button__01 {
        height: 88px;
        border-bottom-width: 6px;
    }

    .button__01 > .text {
        font-size: 32px;
        padding-left: 88px;
    }

    .button__01 > .button_arrow {
        width: 18px;
    }

    .button__01 > .download_icon,
    .button__01 > .contact_icon {
        width: 48px;
        left: 24px;
    }
}

/*---------------------------------
  traceability
---------------------------------*/
.traceability {
    background-color: #FFE800;
    position: relative;
    padding-block: 127px 120px;
}

.traceability__bg {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    aspect-ratio: 683 / 78;
}

.traceability__box {
    border: 4px solid #fff;
    position: relative;
    border-radius: 10px;
    max-width: 800px;
    margin-inline: auto;
    background-color: #FFE800;
}

.traceability__hdg__lv2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-weight: 700;
    width: fit-content;
    margin-top: -50px;
    margin-inline: auto;
    background-color: #FFE800;
    position: relative;
}

.traceability__hdg__lv2 > .bar {
    padding-inline: 25px;
    position: relative;
}

.traceability__hdg__lv2 > .bar > .bar_arrow {
    position: absolute;
    top: 0;
    width: 21px;
    height: 30px;
}

.traceability__hdg__lv2 > .bar > .bar_arrow._left {
    left: 0;
    transform: scale(-1, 1);
}

.traceability__hdg__lv2 > .bar > .bar_arrow._right {
    right: 0;
}

.traceability__hdg__lv2 > .bar > .sub {
    font-size: 24px;
}

.traceability__hdg__lv2 > .main {
    font-size: 26px;
    background: linear-gradient(transparent 90%, #fff 0);
    padding-bottom: 5px;
}

.traceability__hdg__lv2 > .main .large {
    font-size: 36px;
}

.traceability__hdg__lv2 > .main ._orange {
    color: #F37F28;
}

.traceability__hdg__lv2 > .main ._blue {
    color: #3A5BD1;
}

.traceability__text {
    font-size: 18px;
    font-weight: 500;
    padding: 40px 30px;
}

@media (min-width: 1024px) {
    .traceability {
        padding-block: 187px 335px;
    }

    .traceability__box {
        border-width: 8px;
    }

    .traceability__hdg__lv2 {
        margin-top: -100px;
        padding-inline: 20px;
    }

    .traceability__hdg__lv2 > .bar {
        padding-inline: 48px;
    }

    .traceability__hdg__lv2 > .bar > .bar_arrow {
        width: 36px;
        height: 47px;
    }

    .traceability__hdg__lv2 > .bar > .sub {
        font-size: 32px;
    }

    .traceability__hdg__lv2 > .main {
        font-size: 48px;
    }

    .traceability__hdg__lv2 > .main .large {
        font-size: 60px;
    }

    .traceability__text {
        padding: 40px;
    }

}


/*---------------------------------
  assignment
---------------------------------*/
.assignment {
    background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(211,213,222,1) 100%);
    padding-block: 80px;
    position: relative;
    filter: drop-shadow(0 3px 6px rgba(0, 0, 0, .16));
}

.assignment__bg {
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
}

.assignment::after {
    height: 27px;
    background-color: #D3D5DE;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    left: 0;
    right: 0;
    margin-inline: auto;
    bottom: -27px;
}


.assignment__hdg__lv2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    font-weight: 700;
    text-align: center;
    margin-inline: -20px;
}

.assignment__hdg__lv2 ._blue {
    color: #3A5BD1;
}

.assignment__hdg__lv2 > .sub {
    font-size: 28px;
}

.assignment__hdg__lv2 > .main {
    font-size: 32px;
    display: flex;
    flex-direction: column;
}

.assignment__hdg__lv2 > .main > .row {
    width: fit-content;
    margin-inline: auto;
    background: linear-gradient(transparent 90%, #FFE800 0);
}

.assignment__hdg__lv2 > .main .large {
    font-size: 40px;
}

.assignment__hdg__lv2 > .main em {
    position: relative;
    font-weight: inherit;
}

.assignment__hdg__lv2 > .main em::before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #FFE800;
    position: absolute;
    left: 0;
    right: 0;
    margin-inline: auto;
    top: -3px;
}

.assignment__list {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

.assignment__list > li {
    display: flex;
    flex-direction: column;
}

.assignment__list__wrap {
    display: flex;
    align-items: center;
    flex: 1;
}

.assignment__list__box {
    background-color: #fff;
    border-radius: 10px;
    padding: 24px;
    position: relative;
}

.assignment__list__box::after {
    content: "";
    width: 28px;
    height: 24px;
    background-color: #fff;
    position: absolute;
    right: 40px;
    bottom: -24px;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
}

.assignment__list__hdg__lv3 {
    font-size: 24px;
    font-weight: 700;
    text-align: center;
    color: #3A5BD1;
}

.assignment__list__text {
    margin-top: 16px;
    font-weight: 500;
    font-size: 18px;
    line-height: 1.5;
}

.assignment__list__image {
    flex: 1;
}

.assignment__box {
    margin-top: 60px;
    background-color: #fff;
    border-radius: 10px;
    padding: 24px;
    box-shadow: 0 3px 6px #9DA2B5;
}

.assignment__box__column {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.assignment__box__content {
    flex: 1;
}

.assignment__box__hdg__lv3 {
    font-size: 24px;
    font-weight: 700;
    color: #3A5BD1;
    padding-left: 32px;
    position: relative;
}

.assignment__box__hdg__lv3 > .blank_icon {
    width: 24px;
    height: 24px;
    position: absolute;
    left: 0;
    top: 5px;
}

.assignment__box__text {
    margin-top: 16px;
    font-weight: 500;
    font-size: 18px;
    line-height: 1.5;
}

.assignment__box__button {
    margin-top: 16px;
    width: 200px;

}

.button__02 {
    display: flex;
    background-color: #3A5BD1;
    position: relative;
    color: #fff;
    border-radius: 5px;
    align-items: center;
    padding: 18px 20px;
    transition: .4s;
}

.button__02 > .icon {
    width: 14px;
    position: absolute;
    right: 20px;
    top: 50%;
    translate: 0 -50%;
    filter: brightness(0) saturate(100%) invert(86%) sepia(56%) saturate(1%) hue-rotate(324deg) brightness(106%) contrast(101%);
}

.button__02 > .text {
    font-weight: 500;
    font-size: 18px;
}

@media (min-width: 768px) {
    .assignment__hdg__lv2 {
        gap: 8px;
    }

    .assignment__hdg__lv2 > .main {
        flex-direction: row;
    }

    .assignment__list {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 48px;
    }

    .assignment__list > li {
        width: calc((100% / 2) - (48px * 1/2));
    }

    .assignment__box__column {
        flex-direction: row;
        align-items: center;
    }

    .assignment__box__image {
        width: 55%;
    }
}

@media (min-width: 1024px) {
    .assignment {
        padding-block: 120px;
    }

    .assignment::after {
        height: 100px;
        bottom: -100px;
    }

    .assignment__hdg__lv2 > .sub {
        font-size: 32px;
    }

    .assignment__hdg__lv2 > .main {
        font-size: 40px;
    }

    .assignment__hdg__lv2 > .main .large {
        font-size: 48px;
    }

    .assignment__hdg__lv2 > .main em::before {
        top: -3px;
    }

    .assignment__list__box {
        padding: 40px;
    }

    .assignment__box {
        margin-top: 80px;
        padding: 40px;
    }

    .assignment__box__column {
        gap: 40px;
    }
}

/*---------------------------------
  solution
---------------------------------*/
.solution {
    padding-block: 87px 80px;
    position: relative;
}

.solution__bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

.solution__bg > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.solution__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.solution__lead {
    display: inline-block;
    background-color: #F37F28;
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    padding: 8px 8px 8px 0;
    position: relative;
}

.solution__lead::before,
.solution__lead::after {
    content: "";
    position: absolute;
    height: 100%;
    top: 0;
    background-color: #F37F28;
}

.solution__lead::before {
    width: 100%;
    left: -100%;
}

.solution__lead::after {
    width: 20px;
    right: -20px;
    clip-path: polygon(0 0, 100% 0, 50% 100%, 0% 100%);
}

.solution__hdg__lv2 {
    margin-top: 40px;
    font-weight: 700;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
    margin-inline: -20px;
    text-align: center;
}

.solution__hdg__lv2 > .sub {
    font-size: 32px;
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.solution__hdg__lv2 > .sub .border {
    display: inline-block;
    border: 2px solid #F37F28;
    background-color: #fff;
    padding: 4px 8px;
    color: #F37F28;
}

.solution__hdg__lv2 > .bar {
    padding-inline: 20px;
    width: fit-content;
    position: relative;
}

.solution__hdg__lv2 > .bar > .bar_arrow {
    position: absolute;
    top: 0;
    width: 30px;
    aspect-ratio: 1/1;
}

.solution__hdg__lv2 > .bar > .bar_arrow._left {
    left: 0;
    transform: scale(-1, 1);
}

.solution__hdg__lv2 > .bar > .bar_arrow._right {
    right: 0;
}

.solution__hdg__lv2 > .bar > .main {
    font-size: 32px;
    display: flex;
    flex-direction: column;
}

.solution__hdg__lv2 > .bar > .main .large {
    font-size: 48px;
    color: #F37F28;     
}

.solution__hdg__lv2 > .bar > .main > .row {
    background: linear-gradient(transparent 94%, #F37F28 0);
    padding-bottom: 5px;
    width: fit-content;
    margin-inline: auto;
}

.solution__movie {
    margin: 40px auto 0;
    max-width: 850px;
    overflow: hidden;
    border-radius: 10px;
}

.solution__movie iframe {
    width: 100%;
    aspect-ratio: 16 / 9;
    border: none;
}

.solution__box {
    margin: 40px auto 0;
    max-width: 850px;
    border: 2px solid #F37F28;
    background-color: #fff;
    padding: 20px;
    border-radius: 10px;
}

.solution__box__hdg__lv3 {
    font-size: 24px;
    font-weight: 700;
    color: #F37F28;
    padding-left: 32px;
    position: relative;
}

.solution__box__hdg__lv3 > .blank_icon {
    width: 32px;
    position: absolute;
    left: 0;
    top: 0;
    filter: brightness(0) saturate(100%) invert(66%) sepia(86%) saturate(3194%) hue-rotate(345deg) brightness(100%) contrast(91%);
}

.solution__box__hdg__lv3 > .blank_icon img {
    width: 100%;
}

.solution__box__text {
    margin-top: 16px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
}

@media (min-width: 768px) {
    .solution__hdg__lv2 > .bar > .main {
        flex-direction: row;
    }
}

@media (min-width: 1024px) {
    .solution {
        padding-block: 220px 80px;
    }

    .solution__lead {
        font-size: 32px;
        padding: 16px 16px 16px 0;
    }

    .solution__lead::after {
        width: 80px;
        right: -80px;
    }

    .solution__hdg__lv2 {
        margin-top: 80px;
        gap: 10px;
    }

    .solution__hdg__lv2 > .sub {
        font-size: 40px;
    }

    .solution__hdg__lv2 > .sub .border {
        padding: 8px 16px;
    }

    .solution__hdg__lv2 > .bar {
        padding-inline: 30px;
    }

    .solution__hdg__lv2 > .bar > .bar_arrow {
        width: 38px;
    }

    .solution__hdg__lv2 > .bar > .main {
        font-size: 40px;
    }

    .solution__hdg__lv2 > .bar > .main .large {
        font-size: 56px;  
    }

    .solution__hdg__lv2 > .bar > .main > .row {
        background: linear-gradient(transparent 90%, #F37F28 0);
        padding-bottom: 10px;
    }

    .solution__movie {
        margin-top: 80px;
    }

    .solution__box {
        margin-top: 80px;
        padding: 40px;
    }

    .solution__box__hdg__lv3 {
        font-size: 32px;
        padding-left: 48px;
    }

    .solution__box__hdg__lv3 > .blank_icon {
        width: 40px;
        top: 3px;
    }
}


/*---------------------------------
  cta
---------------------------------*/
.cta {
    padding-block: 80px;
    position: relative;
}

.cta__bg {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}

.cta__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cta__head {
    position: relative;
    text-align: center;
}

.cta__hdg__lv2 {
    display: flex;
    flex-direction: column;
    font-weight: 700;
    color: #fff;
    align-items: center;
    text-align: center;
    padding-inline: 20px;
    width: fit-content;
    margin-inline: auto;
    position: relative;
}

.cta__hdg__lv2 > .bar_arrow {
    position: absolute;
    top: 0;
    width: 40px;
    aspect-ratio: 1/1;
    position: absolute;
    top: 50%;
    translate: 0 -50%;
    rotate: 45deg;
    filter: brightness(0) saturate(100%) invert(86%) sepia(56%) saturate(1%) hue-rotate(324deg) brightness(106%) contrast(101%);
}

.cta__hdg__lv2 > .bar_arrow._left {
    left: -20px;
    transform: scale(-1, -1);
}

.cta__hdg__lv2 > .bar_arrow._right {
    right: -20px;
}

.cta__hdg__lv2 > .sub {
    font-size: 18px;
}

.cta__hdg__lv2 > .main {
    font-size: 20px;
}

.cta__hdg__lv2 > .main .large {
    font-size: 28px;
    display: inline-block;
}

.cta__hdg__lv2 > .main .border {
    border-bottom: 6px double #fff;
}

.cta__people {
    position: absolute;
    width: 100px;
    top: 56px;
}

.cta__people._left {
    left: 25px;
}

.cta__people._right {
    right: 10px;
}

.cta__button__list {
    margin-top: 90px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.cta__button__list > li {
    flex: 1;    
}

@media (min-width: 768px) {
    .cta {
        padding-block: 68px 64px;
    }

    .cta__hdg__lv2 {
        flex-direction: row;
    }

    .cta__people {
        top: -100px;
    }

    .cta__people._left {
        left: 0;
    }

    .cta__people._right {
        right: 0;
    }

    .cta__button__list {
        margin-top: 40px;
        flex-direction: row;
    }
}

@media (min-width: 1024px) {
     .cta__hdg__lv {
        padding-inline: 30px;
     }

    .cta__hdg__lv2 > .bar_arrow {
        width: 50px;
    }

    .cta__hdg__lv2 > .sub {
        font-size: 24px;
    }

    .cta__hdg__lv2 > .main {
        font-size: 24px;
    }

    .cta__hdg__lv2 > .main .large {
        font-size: 32px;
    }

    .cta__people {
        width: 200px;
    }

    .cta__people._left {
        left: -110px;
    }

    .cta__people._right {
        right: -110px;
    }

    .cta__button__list {
        gap: 80px;
    }

}

/*---------------------------------
  can
---------------------------------*/
.can {
    padding-block: 80px;
    background: linear-gradient(to bottom, rgba(250,248,226,1) 46%,rgba(252,172,113,1) 100%);
    position: relative;
    filter: drop-shadow(0 3px 6px #6A2E00);
}

.can::after {
    content: "";
    position: absolute;
    height: 27px;
    background-color: #FCAC71;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    left: 0;
    right: 0;
    margin-inline: auto;
    bottom: -27px;
}


.can__hdg__lv2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    margin-inline: auto;
    font-weight: 700;
    position: relative;
}

.can__hdg__lv2 > .bar_arrow {
    position: absolute;
    top: 0;
    width: 26px;
    aspect-ratio: 1 / 1;
    filter: brightness(0) saturate(100%) invert(65%) sepia(77%) saturate(3241%) hue-rotate(345deg) brightness(100%) contrast(91%);
}

.can__hdg__lv2 > .bar_arrow._left {
    left: -31px;
    transform: scale(-1, 1);
}

.can__hdg__lv2 > .bar_arrow._right {
    right: -31px;
}

.can__hdg__lv2 > .sub {
    font-size: 32px;
    background: linear-gradient(transparent 94%, #F37F28 0);
}

.can__hdg__lv2 > .main {
    font-size: 48px;
    color: #F37F28;
    background: linear-gradient(transparent 94%, #F37F28 0);
}

.can__list {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

.can__list > li {
    background-color: #fff;
    padding: 20px;
    flex: 1;
    border-radius: 10px;
}

.can__list__hdg__lv3 {
    display: flex;
    gap: 8px;
    font-weight: 700;
}

.can__list__hdg__lv3 > .num {
    width: 48px;
    height: 48px;
    background-color: #F37F28;
    color: #fff;
    font-size: 35px;
    line-height: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
}

.can__list__hdg__lv3 > .text {
    font-size: 24px;
    color: #F37F28;
    flex: 1;
}

.can__list__text {
    margin-top: 32px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
}

.can__list__images {
    margin-top: 32px;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

.can__list__images > li {
    flex: 1;
    position: relative;
    text-align: center;
}

.can__list__images > li > .arrow {
    width: 24px;
    height: 60px;
    position: absolute;
    left: 0;
    right: 0;
    margin-inline: auto;
    bottom: -60px;
    rotate: 90deg;
}

.can__list__lead {
    margin-top: 40px;
    font-size: 20px;
    font-weight: 700;
    color: #F37F28;
}

@media (min-width: 768px) {
    .can__hdg__lv2 {
        flex-direction: row;
        align-items: baseline;
        background: linear-gradient(transparent 94%, #F37F28 0);
    }

    .can__hdg__lv2 > .sub,
    .can__hdg__lv2 > .main {
        background: none;
    }

    .can__list {
        gap: 50px;
    }

    .can__list > li {
        border-radius: 20px;
    }

    .can__list__hdg__lv3 {
        align-items: center;
    }

    .can__list__images {
        flex-direction: row;
    }

    .can__list__images > li > .arrow {
        left: auto;
        right: -43px;
        top: 50%;
        translate: 0 -50%;
        bottom: auto;
        rotate: 00deg;
    }

    .can__list__lead {
        text-align: center;
        margin-top: 24px;
    }
}

@media (min-width: 1024px) {
    .can {
        padding-block: 125px;
    }

    .can::after {
        height: 100px;
        bottom: -100px;
    }

    .can__hdg__lv2 > .bar_arrow {
        width: 36px;
        top: 20px;
    }

    .can__hdg__lv2 > .bar_arrow._left {
        left: -40px;
    }

    .can__hdg__lv2 > .bar_arrow._right {
        right: -40px;
    }

    .can__hdg__lv2 > .sub {
        font-size: 40px;
    }

    .can__hdg__lv2 > .main {
        font-size: 56px;
    }

    .can__list {
        margin-top: 80px;
        gap: 80px;
    }

    .can__list > li {
        padding: 40px;
    }

    .can__list__hdg__lv3 {
        gap: 16px;
    }

    .can__list__hdg__lv3 > .num {
        width: 80px;
        height: 80px;
        font-size: 60px;
    }

    .can__list__hdg__lv3 > .text {
        font-size: 32px;
    }

    .can__list__lead {        
        font-size: 24px;
    }
}
/*---------------------------------
  merit
---------------------------------*/
.merit {
    padding-block: 110px 80px;
    background-color: #F37F28;
}

.merit_arrow {
    width: 80px;
    height: 64px;
    margin-inline: auto;
}

.merit__hdg__lv2 {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    font-weight: 700;
    color: #fff;
    text-align: center;
    position: relative;
}

.merit__hdg__lv2 > .sub {
    font-size: 32px;
    background: linear-gradient(transparent 94%, #fff 0);
    padding-bottom: 4px;
}

.merit__hdg__lv2 > .main {
    font-size: 48px;
    color: #FFE800;
    background: linear-gradient(transparent 94%, #fff 0);
    padding-bottom: 4px;
}

.merit__bar {
    margin: 20px auto 0;
    text-align: center;
    width: fit-content;
    position: relative;
}

.merit__bar > .bar_arrow {
    position: absolute;
    top: 50%;
    translate: 0 -50%;
    rotate: 45deg;
    width: 40px;
    aspect-ratio: 1 / 1;
    filter: brightness(0) saturate(100%) invert(100%) sepia(10%) saturate(0%) hue-rotate(211deg) brightness(111%) contrast(103%);
}

.merit__bar > .bar_arrow._left {
    left: -36px;
    transform: scale(-1, -1);
}

.merit__bar > .bar_arrow._right {
    right: -36px;
}

.merit__lead {
    display: inline-block;
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    position: relative;
}

.merit__lead em {
    color: #FFE800;
    font-weight: inherit;
}

.merit__list {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.merit__list > li {
    background-color: #fff;
    border-radius: 10px;
    padding: 20px;
    flex: 1;
    border-bottom: 8px solid #845029;
}

.merit__list__num {
    background-color: #F37F28;
    border-radius: 10px;
    width: 60px;
    height: 60px;
    color: #fff;
    font-size: 45px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.merit__list__image {
    width: 136px;
    margin-inline: auto;
    margin-top: -28px;
}

.merit__list__text {
    margin-top: 24px;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}

@media (min-width: 768px) {
    .merit__hdg__lv2 {
        flex-direction: row;
        justify-content: center;
        background: linear-gradient(transparent 94%, #fff 0);
        padding-bottom: 4px;
        width: fit-content;
        margin-inline: auto;
        align-items: baseline;
    }

    .merit__hdg__lv2 > .sub,
    .merit__hdg__lv2 > .main {
        background: none;
    }

    .merit__list {
        flex-direction: row;
    }

}

@media (min-width: 1024px) {
    .merit {
        padding-block: 184px 120px;
    }

    .merit__hdg__lv2 {
        margin-top: 40px;
    }

    .merit__hdg__lv2 > .sub {
        font-size: 40px;
    }

    .merit__hdg__lv2 > .main {
        font-size: 56px;
    }

    .merit__bar {
        margin-top: 32px;
    }

    .merit__bar > .bar_arrow {
        width: 50px;
    }

    .merit__bar > .bar_arrow._left {
        left: -46px;
    }

    .merit__bar > .bar_arrow._right {
        right: -46px;
    }

    .merit__lead {
        font-size: 32px;
    }

    .merit__list {
        margin-top: 80px;
        gap: 48px;
    }

    .merit__list__num {
        width: 80px;
        height: 80px;
        font-size: 60px;
    }

    .merit__list__image {
        margin-top: -46px;
    }

    .merit__list__text {
        font-size: 28px;
    }
}


/*---------------------------------
  for
---------------------------------*/
.for {
    padding-block: 80px;
    background-color: #fff;
    position: relative;
    z-index: 1;
}

.for__hdg__lv2 {
    font-weight: 700;
    text-align: center;
}

.for__hdg__lv2 > .bar {
    width: fit-content;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}

.for__hdg__lv2 > .bar > .bar_arrow {
    position: absolute;
    bottom: -5px;
    width: 28px;
    height: 36px;
    filter: brightness(0) saturate(100%) invert(44%) sepia(99%) saturate(406%) hue-rotate(153deg) brightness(97%) contrast(93%);
}

.for__hdg__lv2 > .bar > .bar_arrow._left {
    left: -14px;
    transform: scale(-1, 1);
}

.for__hdg__lv2 > .bar > .bar_arrow._right {
    right: -14px;
}

.for__hdg__lv2 > .bar > .sub {
    font-size: 24px;
    background: linear-gradient(transparent 90%, #1E98CE 0);
    padding-bottom: 4px;
}

.for__hdg__lv2 > .bar > .main {
    font-size: 32px;
    background: linear-gradient(transparent 90%, #1E98CE 0);
    padding-bottom: 4px;
    color: #0D2EA1;
}

.for__block {
    margin-top: 40px;
    position: relative;
}

.for__fukidashi {
    width: 296px;
    margin-inline: auto;
    background-color: #3A5BD1;
    border-radius: 10px;
    padding: 20px 30px;
    position: relative;
    color: #FFE800;
    font-size: 32px;
    font-weight: 700;
    box-sizing: border-box;
}

.for__fukidashi > .large {
    font-size: 40px;
}

.for__fukidashi::after {
    content: "";
    width: 24px;
    height: 24px;
    background-color: #3A5BD1;
    position: absolute;
    right: 40px;
    bottom: -24px;
    clip-path: polygon(0 0, 0 100%, 100% 0);
}

.for__list {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.for__list > li {
    flex: 1;
}

.for__list__image {
    width: 335px;
    margin-inline: auto;
}

.for__list__hdg__lv3 {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
    font-weight: 700;
    text-align: center;
    margin-top: 40px;
}

.for__list__hdg__lv3 > .sub {
    border: 1px solid #3A5BD1;
    font-size: 19px;
    font-weight: 700;
    color: #3A5BD1;
    padding: 8px 24px;
    width: fit-content;
    margin-inline: auto;
}

.for__list__hdg__lv3 > .main {
    font-size: 33px;
}

.for__list__text {
    margin-top: 16px;
    font-size: 18px;
    font-weight: 500;
    color: #737684;
}

.for__list__desc {
    margin-top: 16px;
}

.for__list__desc > div {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-weight: 500;
    color: #737684;
}

.for__list__desc > div > dt {
    border: 1px solid #707070;
    font-size: 15px;
    padding: 4px;
    width: fit-content;
}

.for__list__desc > div > dd {
    font-size: 18px;
}

.for__block + .recommend__box {
    margin-top: 140px;
}

.recommend__box {
    margin-top: 60px;
    border: 2px solid #F37F28;
    background-color: #fff;
    padding: 40px 20px;
    border-radius: 10px;
    position: relative;
}

.limited {
    width: 104px;
    height: 104px;
    background-color: #F37F28;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2;
    border-radius: 50%;
    color: #fff;
    position: absolute;
    right: 20px;
    top: -65px;
}

.recommend__box__hdg__lv4 {
    font-size: 24px;
    font-weight: 700;
    color: #F37F28;
    padding-left: 40px;
    position: relative;
    font-weight: 700;
}

.recommend__box__hdg__lv4 .blank_icon {
    width: 32px;
    height: 32px;
    position: absolute;
    left: 0;
    top: 5px;
    filter: brightness(0) saturate(100%) invert(60%) sepia(90%) saturate(2526%) hue-rotate(345deg) brightness(100%) contrast(91%);
}

.recommend__box__hdg__lv4 .blank_icon img {
    width: 100%;
}

.recommend__box__column {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.recommend__box__content {
    flex: 1;
}

.recommend__box__lead {
    text-align: center;
}

.recommend__box__lead > .bar {
    padding-inline: 20px;
    position: relative;
}

.recommend__box__lead > .bar > .bar_arrow {
    position: absolute;
    top: 50%;
    translate: 0 -50%;
    rotate: 45deg;
    width: 26px;
    aspect-ratio: 1 / 1;
    filter: brightness(0) saturate(100%) invert(60%) sepia(90%) saturate(2526%) hue-rotate(345deg) brightness(100%) contrast(91%);
}

.recommend__box__lead > .bar > .bar_arrow._left {
    left: -5px;
    transform: scale(-1, -1);
}

.recommend__box__lead > .bar > .bar_arrow._right {
    right: -5px;
}

.recommend__box__lead > .bar > .text {
    font-size: 24px;
    font-weight: 700;
    background: linear-gradient(transparent 90%, #F37F28 0);
    padding-bottom: 2px;
}

.recommend__box__text {
    margin-top: 24px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
}

.recommend__box__button {
    margin-top: 24px;
    max-width: 400px;
}

.button__03 {
    display: flex;
    text-decoration: none;
    background: linear-gradient(to bottom, rgba(255,216,186,1) 0%,rgba(243,127,40,1) 100%);
    border-bottom: 4px solid #845029;
    padding: 24px;
    height: 80px;
    align-items: center;
    box-sizing: border-box;
    position: relative;
    border-radius: 5px;
}

.button__03 > .button_arrow {
    filter: brightness(0) saturate(100%) invert(100%) sepia(10%) saturate(0%) hue-rotate(211deg) brightness(111%) contrast(103%);
    position: absolute;
    width: 14px;
    height: 12px;
    right: 20px;
    top: 50%;
    translate: 0 -50%;
}

.button__03 > .text {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 2px 4px #F37F28;
}

.recommend__box__desc {
    margin-top: 16px;
}

.recommend__box__desc > div {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-weight: 500;
}

.recommend__box__desc > div > dt {
    width: fit-content;
    border: 1px solid #F37F28;
    font-size: 18px;
    padding: 4px;
}

.recommend__box__list > li {
    font-size: 18px;
    padding-left: 16px;
    position: relative;
}

.recommend__box__list > li::before {
    content: "・";
    color: #F37F28;
    position: absolute;
    left: 0;
    top: 0;
}

@media (min-width: 768px) {
    .for__hdg__lv2 > .bar {
        flex-direction: row;
        align-items: baseline;
        background: linear-gradient(transparent 94%, #1E98CD 0);
    }

    .for__hdg__lv2 > .bar > .bar_arrow {
        bottom: 0;
    }

    .for__hdg__lv2 > .bar > .bar_arrow._left {
        left: -34px;
    }

    .for__hdg__lv2 > .bar > .bar_arrow._right {
        right: -34px;
    }

    .for__hdg__lv2 > .bar > .sub,
    .for__hdg__lv2 > .bar > .main {
        background: none;
    }

    .for__block {
        margin-top: 120px;
    }

    .for__fukidashi {
        position: absolute;
        right: 0;
        top: -100px;
    }

    .for__list {
        flex-direction: row;
    }

    .for__list > li {
        max-width: 400px;
        margin-inline: auto;
    }

    .recommend__box__column {
        flex-direction: row;
    }

    .recommend__box__image {
        width: 52%;
    }
}

@media (min-width: 1024px) {
    .for {
        padding-block: 120px;
    }

    .for__hdg__lv2 > .bar > .bar_arrow {
        width: 36px;
        height: 47px;
        bottom: 10px;
    }

    .for__hdg__lv2 > .bar > .bar_arrow._left {
        left: -44px;
    }

    .for__hdg__lv2 > .bar > .bar_arrow._right {
        right: -44px;
    }

    .for__hdg__lv2 > .bar > .sub {
        font-size: 40px;
    }

    .for__hdg__lv2 > .bar > .main {
        font-size: 56px;
    }

    .for__list__image {
        width: 400px;
    }

    .for__list__hdg__lv3 > .sub {
        font-size: 24px;
    }

    .for__list__hdg__lv3 > .main {
        font-size: 40px;
    }

    .for__list__desc > div > dt {
        font-size: 18px;
    }

    .for__block + .recommend__box {
        margin-top: 120px;
    }

    .recommend__box {
        margin-top: 80px;
        padding: 40px;
    }

    .limited {
        width: 160px;
        height: 160px;
        font-size: 40px;
        right: 40px;
    }

    .recommend__box__hdg__lv4 {
        font-size: 32px;
        padding-left: 48px;
    }

    .recommend__box__hdg__lv4 .blank_icon {
        width: 40px;
        height: 40px;
        top: 5px;
    }

    .recommend__box__column {
        gap: 40px;
    }

    .recommend__box__lead > .bar {
        padding-inline: 30px;
    }

    .recommend__box__lead > .bar > .bar_arrow {
            width: 34px;
    }

    .recommend__box__lead > .bar > .text {
        font-size: 32px;
    }

    .button__03 > .text {
        font-size: 24px;
    }

    .button__03 > .button_arrow {
        width: 18px;
    }

}
