@charset "UTF-8";

/* @font-face {
    font-family: 'GTAmerica-Regular';
    src: url('/html/user_data/assets/fonts/GT-America-Standard-Regular.otf');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'GTAmerica-Bold';
    src: url('/html/user_data/assets/fonts/GT-America-Standard-Bold.otf');
    font-weight: bold;
    font-style: normal;
} */

.container {
    font-family: メイリオ, Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;;
}

.container p {
    line-height: /*1.6*/1.8;
}

.container a {
    cursor: pointer;
}

h2.page-title {
    display: none;
}

.container.content-asset-container {
    width: 100%;
    max-width: initial;
    padding: 0;
}

.travel-buddy-wrapper p {
    margin-bottom: 0;
}

.travel-buddy-wrapper .full-width {
    width: 100%;
}

.travel-buddy-wrapper .width-padding {
    padding: 0 3%;
}

.travel-buddy-wrapper .description p {
    text-align: center;
    font-size: 4.0vw;
    color: #fff;
}

.travel-buddy-wrapper .white-border {
    border: 2vw solid #f6f6f6;
    box-shadow: -2px 4px 10px 0px #000000;
    background-color: #f6f6f6;
}

.travel-buddy-wrapper .title h4 {
    font-family: 'Roboto', sans-serif;
    text-align: center;
    font-size: 6.5vw;
    font-weight: bold;
    color: #fff;
    text-transform: uppercase;
    padding: 3% 0;
}

.section-1 {
    min-height: /*260vw*/220vw;
}

.section-2,
.section-3,
.section-4 {
    padding-bottom: 20%;
}

@media (min-width: 1024px) {
    .section-2, .section-3, .section-4 {
        padding-bottom: 65vw;
    }
}

.section-1 .content .description p {
    color: #000;
}

.section-1 .content .title h3 {
    color: #f77014;
    font-size: 11vw;
    font-weight: bold;
    line-height: 8.5vw;
}

.section-2 .content .title h4 {
    color: #fb91e8;
}

.section-3 .content .title h4 {
    color: #f9e00d;
}

.section-4 .content .title h4 {
    color: #69ecf8;
    margin-top: 5%;
}

.section-1 .content .title {
    top: 9%;
    left: 50%;
    transform: translateX(-50%) rotate(-6deg) scaleY(2.5);
}

.section-1 .content .description {
    top: /*59.5%*/75%;
    left: 50%;
    width: 100%;
    transform: translateX(-50%);
}

.btn_page {
    text-align: center;
    margin: 5% auto 0;
    width: /*80%*/65%;
}
@media (min-width: 768px) {
    .btn_page {
        width: 50%;
    }
}

.smallBtn {
    padding: 1.0em 0;
    display: block;
    font-size: 1.0rem;
    transition-duration: 0.5s;
    color: #272727;
    background-color: #fff;
    border: 1px solid #f5f5f5;
    box-shadow: 0 2px 7px -2px #333;
    border-radius: 50px;
    font-weight: 700;
}
@media (min-width: 768px) {
    .smallBtn {
        padding: 0.8em 0;
        font-size: 1.6rem;
    }
}
@media (min-width: 1024px) {
    .smallBtn {
        padding: 1.2em 0;
        font-size: 1.0rem;
    }
}


.section-2 {
    padding-top: 3%;
    background: linear-gradient(90deg, #cb40d1, #a832d4);
}

.section-3 {
    padding-top: 3%;
    background: linear-gradient(90deg, #f18e0f, #edb546);
}

.section-4 {
    padding-top: /*3%*/2%;
    background: linear-gradient(90deg, #01a2f3, #017be8);
}

.section-2 .banner,
.section-3 .banner,
.section-4 .banner {
    min-height: 140vw;
}

.section-2 .banner .image-ticket img,
.section-3 .banner .image-ticket img,
.section-4 .banner .image-ticket img {
    width: 100%;
}

.section-2 .banner .image-ticket {
    top: /*-5%*/-3.95%;
    left: 6%;
    z-index: 1;
    width: 35%;
}

.section-2 .banner .image-1 {
    top: -3%;
    left: 32%;
    z-index: 0;
    transform: rotate(-7deg);
    width: 58%;
}

.section-2 .banner .image-2 {
    top: 58%;
    left: 11%;
    z-index: 0;
    transform: rotate(5deg);
    width: 72%;
}

.section-3 .banner .image-ticket {
    top: -7.5%;
    right: 8%;
    z-index: 1;
    width: 35%;
}

.section-3 .banner .image-1 {
    top: -2%;
    left: 10%;
    z-index: 0;
    transform: rotate(-7deg);
    width: 65%;
}

.section-3 .banner .image-2 {
    top: 61%;
    left: 21%;
    z-index: 0;
    transform: rotate(5deg);
    width: 72%;
}

.section-4 .banner .image-ticket {
    top: -7%;
    left: 7%;
    z-index: 1;
    width: 35%;
}

.section-4 .banner .image-1 {
    top: -3%;
    left: 25%;
    z-index: 0;
    transform: rotate(4deg);
    width: 65%;
}

.section-4 .banner .image-2 {
    top: 64%;
    left: 12%;
    z-index: 0;
    transform: rotate(-9deg);
    width: 72%;
}

/*Animation*/
.travel-buddy-wrapper .section-1 .title,
.travel-buddy-wrapper .section-1 .description {
    opacity: 1;
}

.travel-buddy-wrapper .title,
.travel-buddy-wrapper .description {
    opacity: 0;
}

.content .has-animation.load-animation {
    animation: customFadeInUp 0.8s ease-in-out;
    opacity: 1;
}

.background-image {
    overflow: hidden;
}

.background-image.has-animation img,
.background-image.has-animation picture {
    transform: scale(1);
}

.background-image.load-animation img,
.background-image.load-animation picture {
    transition: ease-in 1.5s;
    transform: scale(1.05);
}

@media (min-width: 768px) {
    .section-1,
    .section-2,
    .section-3,
    .section-4 {
        min-height: 60vw;
    }

    .travel-buddy-wrapper .section-1 .description p {
        font-size: 1.8vw;
        margin: 0;
    }

    .section-1 .content .description {
        top: /*6%*/4.5%;
        left: 60%;
        width: 42%;
        transform: translateX(-50%);
    }

    .travel-buddy-wrapper .description p {
        text-align: left;
        font-size: 3.0vw;
    }
}

@media (min-width: 1024px) {
    .travel-buddy-wrapper .section-1 .description p {
        font-size: 1.3vw;
    }

    .travel-buddy-wrapper .description p {
        font-size: 1.25vw;
        /* color: #fff; */
        /* margin-bottom: 4%; */
    }

    .travel-buddy-wrapper .title h4 {
        text-align: left;
        font-size: 2.3vw;
        padding: 0;
        margin-bottom: 4%;
    }

    .travel-buddy-wrapper .white-border {
        border: 1vw solid #f6f6f6;
        box-shadow: -2px 4px 10px 0px #000000;
    }

    .section-1 {
        min-height: auto;
    }

    /* .section-1,
    .section-2,
    .section-3,
    .section-4 {
        min-height: 60vw;
    } */

    .section-1 .content .title {
        top: 10%;
        left: 25%;
    }

    .section-1 .content .title h3 {
        font-size: 4vw;
        line-height: 3.5vw;
    }

    .section-1 .content .description {
        top: 8.5%;
        /* left: 60%;
        width: 42%;
        transform: translateX(-50%); */
    }

    .section-1 .content .description p {
        line-height: 1.8;
    }

    .btn_page {
        margin: 4% auto 0 0;
        width: min(50%, 240px);
    }

    .section-2 .banner,
    .section-3 .banner,
    .section-4 .banner {
        min-height: auto;
    }

    .section-2 .banner .image-ticket img,
    .section-3 .banner .image-ticket img,
    .section-4 .banner .image-ticket img {
        width: 100%;
    }

    .section-2 .banner .image-ticket {
        top: -5.5vw;
        left: 1%;
        z-index: 2;
        width: 17%;
    }

    .section-2 .banner .image-1 {
        top: -4vw;
        left: 8%;
        transform: rotate(-2deg);
        width: 37%;
        z-index: 1;
    }

    .section-2 .banner .image-2 {
        left: 45%;
        z-index: 0;
        transform: rotate(5deg);
        width: 50%;
    }

    .section-2 .content {
        position: absolute;
        left: 49%;
        top: 106vw;
        width: 40%;
    }

    .section-3 .banner .image-ticket {
        top: -7vw;
        right: 3%;
        z-index: 2;
        width: 17%;
    }

    .section-3 .banner .image-1 {
        top: -5vw;
        left: 50%;
        z-index: 1;
        transform: rotate(-2deg);
        width: 40%;
    }

    .section-3 .banner .image-2 {
        left: 5%;
        z-index: 0;
        transform: rotate(3deg);
        width: 48%;
    }

    .section-3 .content {
        position: absolute;
        left: 6%;
        top: 171.25vw;
        width: 42%;
    }

    .section-4 .banner .image-ticket {
        top: -8.8vw;
        left: 2%;
        z-index: 2;
        width: 17%;
    }

    .section-4 .banner .image-1 {
        top: -6vw;
        left: 7%;
        z-index: 1;
        transform: rotate(4deg);
        width: 37%;
    }

    .section-4 .banner .image-2 {
        top: 64%;
        left: 43%;
        z-index: 0;
        transform: rotate(-5deg);
        width: 50%;
    }

    .section-4 .content {
        position: absolute;
        left: 47%;
        top: 238vw;
        width: 42%;
    }
}

@media screen and (min-width: 991px) {

    .section-2 .banner .image-ticket img,
    .section-3 .banner .image-ticket img,
    .section-4 .banner .image-ticket img {
        width: 100%;
    }

    .section-3 .banner .image-ticket {
        top: -7vw;
        right: 5%;
        z-index: 2;
    }
}

@media screen and (min-width: 1200px) {

    .section-2 .banner .image-ticket img,
    .section-3 .banner .image-ticket img,
    .section-4 .banner .image-ticket img {
        width: 100%;
    }

    .section-3 .banner .image-ticket {
        top: -7vw;
        right: 0%;
        z-index: 2;
    }
}

@media screen and (min-width: 1600px) {
    .travel-buddy-wrapper .description p {
        font-size: 1.1vw;
    }

    .section-2 .banner .image-ticket img,
    .section-3 .banner .image-ticket img,
    .section-4 .banner .image-ticket img {
        width: 100%;
    }

    .section-3 .banner .image-ticket {
        top: -7vw;
        right: 5%;
        z-index: 2;
    }
}

/*
221116追記
----------------------------------------*/
@media screen and (max-width: 1200px) {

    .section-2 .banner .image-ticket img,
    .section-3 .banner .image-ticket img,
    .section-4 .banner .image-ticket img {
        width: 100%;
    }

    .section-3 .banner .image-ticket {
        top: -7vw;
        right: 0%;
        z-index: 2;
    }
}

@media screen and (max-width: 767px) {
    .section p {
        margin: 0 24px;
    }
}
@media screen and (min-width: 768px) {
    .section p {
        margin: 0 48px;
    }
}
@media screen and (min-width: 1024px) {
    .section p {
        margin: 0;
    }
}

@media screen and (max-width: 1023px) {
    .section:nth-of-type(1) p {
        line-height: 2.0;
    }
}