@charset "UTF-8";
.wrapper {
	/* overflow: hidden; */
}
.step {
    padding: 57px 5% 0;
}
.step__inner {
    max-width: 1200px;
    margin: 0 auto;
}
.step p {
    font-size: 22px;
    font-weight: bold;
    line-height: 1.8;
    text-align: center;
}
.step__visual {
    max-width: 1160px;
    margin: 30px auto 0;
}
@media screen and (max-width: 767px) {
    .step {
        padding: 50px 0 0;
    }
    .step p {
        padding: 0 16px;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.8;
        text-align: center;
    }
    .step__visual-wrap {
        width: 100%;
        padding: 0 16px;
        overflow: scroll;
    }
    .step__visual {
        max-width: 1160px;
        margin: 20px auto 0;
    }
    .step__visual img {
        display: block;
        max-width: none;
        width: 800px;
        height: auto;
    }
}
/* -------------------------------- */
.trip {
    position: relative;
    padding: 120px 5% 80px;
    background-color: #21A5A6;
}
.vector {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%,0);
    border: 90px solid rgba(0,0,0,0);
    border-top: 50px solid #fff;
}
.trip__inner {
    max-width: 1200px;
    margin: 0 auto;
}
.trip h2 {
    width: 460px;
    margin: 0 auto;
}
.trip h2 span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 417px;
    height: 52px;
    border-radius: 30px;
    background-color: #fff;
    color: #21A5A6;
    font-size: 21px;
    font-weight: bold;
    text-align: center;
}
.trip__description {
    margin-top: 30px;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.8;
    text-align: center;
}
.trip ul {
    display: flex;
    flex-direction: column;
    gap: 82px;
    margin-top: 82px;
}
.trip ul li {
    position: relative;
    padding: 80px 30px 0;
    background-color: #f5fafb;
    border-radius: 16px;
}
.trip ul li .trip__icon {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 104px;
}
.trip ul li h3 {
    font-size: 30px;
    font-weight: bold;
    line-height: 1.6;
    text-align: center;
}
.trip ul li:first-child .trip__visual {
    max-width: 1093px;
    margin: 0 auto;
}
.trip ul li:nth-child(2) {
    padding-bottom: 53px;
}
.trip ul li:nth-child(2) .trip__visual {
    max-width: 970px;
    margin: 20px auto;
}
.trip ul li:nth-child(2) .trip__memo {
    max-width: 950px;
    margin: 25px auto;
    line-height: 1.8;
}
.trip ul li:nth-child(3) {
    padding-bottom: 76px;
}
.trip ul li:nth-child(3) .trip__visual {
    position: absolute;
    right: 54px;
    bottom: 0;
    max-width: 216px;
}
.trip ul li:nth-child(3) .trip__memo {
    max-width: 950px;
    margin: 25px auto;
    font-size: 20px;
    line-height: 1.8;
}
@media screen and (max-width: 767px) {
    .trip {
        padding: 70px 16px 50px;
    }
    .vector {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%,0);
        border: 60px solid rgba(0,0,0,0);
        border-top: 40px solid #fff;
    }
    .trip h2 {
        width: 100%;
    }
    .trip h2 span {
        width: 100%;
        height: 52px;
        border-radius: 30px;
        background-color: #fff;
        color: #21A5A6;
        font-size: 18px;
        font-weight: bold;
        text-align: center;
    }
    .trip__description {
        margin-top: 20px;
        color: #fff;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.8;
        text-align: center;
    }
    .trip ul {
        display: flex;
        flex-direction: column;
        gap: 50px;
        margin-top: 80px;
    }
    .trip ul li {
        position: relative;
        padding: 50px 20px 0;
        background-color: #f5fafb;
        border-radius: 16px;
    }
    .trip ul li .trip__icon {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%,-50%);
        width: 70px;
    }
    .trip ul li h3 {
        font-size: 20px;
        font-weight: bold;
        line-height: 1.6;
        text-align: center;
    }
    .trip ul li:first-child .trip__visual {
        max-width: 840px;
        margin: 30px auto 0;
    }
    .trip ul li:nth-child(2) {
        padding-bottom: 53px;
    }
    .trip ul li:nth-child(2) .trip__visual {
        max-width: 970px;
        margin: 20px auto;
    }
    .trip ul li:nth-child(2) .trip__memo {
        max-width: 950px;
        margin: 25px auto 0;
        line-height: 1.8;
    }
    .trip ul li:nth-child(3) {
        padding-bottom: 76px;
    }
    .trip ul li:nth-child(3) .trip__visual {
        position: absolute;
        right: 20px;
        bottom: 0;
        max-width: 70px;
    }
    .trip ul li:nth-child(3) .trip__memo {
        max-width: 950px;
        margin: 25px auto 0;
        font-size: 16px;
        line-height: 1.8;
    }
}
/* -------------------------------- */
.bring {
    position: relative;
    padding: 120px 5% 80px;
    background-color: #edf3fd;
}
.vector2 {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%,0);
    border: 90px solid rgba(0,0,0,0);
    border-top: 50px solid #21A5A6;
}
.bring__inner {
    max-width: 1200px;
    margin: 0 auto;
}
.bring h2 {
    width: 446px;
    margin: 0 auto;
}
.bring__text1 {
    margin-top: 25px;
    font-weight: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 1.8;
}
.bring__list {
    display: flex;
    justify-content: center;
    margin: 30px auto 0;
    max-width: 767px;
    padding: 27px 16px 32px;
    background-color: #fff;
}
.bring__text2 {
    margin-top: 25px;
    font-weight: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 1.8;
}
.bring__text2 span {
    color: #024b9e;
}
.bring__list ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.bring__list ul li {
    display: flex;
    align-items: center;
    gap: 17px;
    font-size: 20px;
    font-weight: bold;
}
.bring__list ul li .icon {
    width: 21px;
    min-width: 21px;
}
.bring__list .memo {
    margin-top: 10px;
}
.bring__contents ul {
    display: flex;
    flex-direction: column;
    gap: 82px;
    margin-top: 82px;
}
.bring__contents ul li {
    position: relative;
    padding: 80px 18px 0;
    background-color: #357bcc;
    color: #fff;
    border-radius: 16px;
}
.bring__contents ul li .bring__icon {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 104px;
}
.bring__contents ul li h3 {
    font-size: 30px;
    font-weight: bold;
    line-height: 1.6;
    text-align: center;
}
.bring__contents ul li:first-child .bring__visual {
    padding-left: 42px;
}
.bring__contents ul li:nth-child(2) {
    padding-bottom: 60px;
}
.bring__contents ul li:nth-child(2) .trip__visual {
    max-width: 970px;
    margin: 20px auto;
}
.bring__contents ul li:nth-child(2) .trip__memo {
    max-width: 950px;
    margin: 25px auto;
    line-height: 1.8;
}
.bring__contents ul li:nth-child(3) {
    padding-bottom: 76px;
}
.bring__contents ul li:nth-child(3) .trip__visual {
    position: absolute;
    top: 50%;
    right: 45px;
    transform: translate(0,-50%);
    max-width: 264px;
}
.bring__contents ul li:nth-child(3) .bring__memo1 {
    max-width: 950px;
    margin: 25px auto;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.8;
}
.bring__contents ul li:nth-child(3) .bring__memo1 span {
    color: #ffd500;
}
.bring__contents ul li:nth-child(3) .bring__memo2 {
    display: flex;
    align-items: center;
    gap: 25px;
    max-width: 950px;
    margin: 13px auto;
}
.bring__contents ul li:nth-child(3) .bring__memo2 > div {
    display: flex;
    align-items: center;
    gap: 6px;
}
.bring__contents ul li:nth-child(3) .bring__memo2 > div .ttl {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 26px;
    border: 1px solid #fff;
    border-radius: 5px;
}
@media screen and (max-width: 767px) {
    .bring {
        padding: 70px 16px 50px;
    }
    .vector2 {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%,0);
        border: 60px solid rgba(0,0,0,0);
        border-top: 40px solid #21A5A6;
    }
    .bring h2 {
        width: 100%;
    }
    .bring__text1 {
        margin-top: 25px;
        font-weight: 18px;
        font-weight: bold;
        text-align: center;
        line-height: 1.8;
    }
    .bring__list {
        display: flex;
        justify-content: center;
        margin: 30px auto 0;
        max-width: 767px;
        padding: 20px;
        background-color: #fff;
    }
    .bring__text2 {
        margin-top: 25px;
        font-weight: 16px;
        font-weight: bold;
        text-align: center;
        line-height: 1.8;
    }
    .bring__text2 span {
        color: #024b9e;
    }
    .bring__list ul {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }
    .bring__list ul li {
        display: flex;
        align-items: center;
        gap: 17px;
        font-size: 16px;
        font-weight: bold;
    }
    .bring__list ul li .icon {
        width: 21px;
        min-width: 21px;
    }
    .bring__list .memo {
        margin-top: 10px;
    }
    .bring__contents ul {
        display: flex;
        flex-direction: column;
        gap: 50px;
        margin-top: 80px;
    }
    .bring__contents ul li {
        position: relative;
        padding: 50px 16px 0;
        background-color: #357bcc;
        color: #fff;
        border-radius: 16px;
    }
    .bring__contents ul li .bring__icon {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translate(-50%,-50%);
        width: 70px;
    }
    .bring__contents ul li h3 {
        font-size: 20px;
        font-weight: bold;
        line-height: 1.6;
        text-align: center;
    }
    .bring__contents ul li:first-child .bring__visual {
        margin-top: 30px;
        padding-left: 0;
    }
    .bring__contents ul li:nth-child(2) {
        padding-bottom: 16px;
    }
    .bring__contents ul li:nth-child(2) .trip__visual {
        max-width: 970px;
        margin: 20px auto;
    }
    .bring__contents ul li:nth-child(2) .trip__memo {
        max-width: 950px;
        margin: 25px auto;
        line-height: 1.8;
    }
    .bring__contents ul li:nth-child(3) {
        padding-bottom: 16px;
    }
    .bring__contents ul li:nth-child(3) .trip__visual {
        position: relative;
        top: initial;
        right: initial;
        transform: initial;
        max-width: 200px;
        margin: 30px auto 0;
    }
    .bring__contents ul li:nth-child(3) .bring__memo1 {
        max-width: 950px;
        margin: 25px auto;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.8;
    }
    .bring__contents ul li:nth-child(3) .bring__memo1 span {
        color: #ffd500;
    }
    .bring__contents ul li:nth-child(3) .bring__memo2 {
        align-items: flex-start;
        flex-direction: column;
        gap: 25px;
        max-width: 950px;
        margin: 13px auto;
    }
    .bring__contents ul li:nth-child(3) .bring__memo2 > div {
        display: flex;
        align-items: center;
        gap: 6px;
    }
    .bring__contents ul li:nth-child(3) .bring__memo2 > div .ttl {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 46px;
        height: 26px;
        border: 1px solid #fff;
        border-radius: 5px;
    }
}