@charset "utf-8";

.vision_message {
    padding-top: min(21.325vw, 91.7px);
}
@media screen and (min-width: 920px){
    .vision_message {
        padding-top: min(10.724vw, 200px);
    }
}

.vision_message_head {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(13.697vw, 58.9px);
    padding: 0 min(11.395vw, 49px) min(21.395vw, 92px) min(11.8604vw, 51px);
}
@media screen and (min-width: 920px){
    .vision_message_head {
        flex-direction: row;
        justify-content: center;
        gap: min(4.28125vw, 82.2px);
        padding: 0 0 min(10.46875vw, 201px) 0;
    }
}

.vision_message_catch {
    display: block;
    width: min(26.102vw, 112.24px);
    height: min(75.732vw, 325.65px);
}
@media screen and (min-width: 920px){
    .vision_message_catch {
        width: min(10.0166vw, 192.32px);
        height: min(29.0625vw, 558px);
    }
}

.vision_message_catch img {
    width: 100%;
    height: 100%;
}

.vision_message_text {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(3.72vw, 16px);
}
@media screen and (min-width: 920px){
    .vision_message_text {
        width: fit-content;
        gap: min(2.8125vw, 54px);
        padding-top: min(12.135vw, 233px);
    }
}

.vision_message_text p {
    font-family: var(--font-serif);
    font-size: min(4.186vw, 18px);
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0.05em;
    white-space: nowrap;
}
@media screen and (min-width: 920px){
    .vision_message_text p {
        font-size: min(0.9375vw, 18px);
    }
}

.vision_message_text p:nth-child(1) {
    transition-delay: 0s;
}
.vision_message_text p:nth-child(2) {
    transition-delay: 0.02s;
}
.vision_message_text p:nth-child(3) {
    transition-delay: 0.04s;
}
.vision_message_text p:nth-child(4) {
    transition-delay: 0.06s;
}
.vision_message_text p:nth-child(5) {
    transition-delay: 0.08s;
}

.vision_message_visual {
    width: 100%;
    height: min(126.046vw, 542px);
    max-width: 430px;
    margin: 0 auto;
    position: relative;
}
@media screen and (min-width: 920px){
    .vision_message_visual {
        width: min(86.4583vw, 1660px);
        height: min(108.95vw, 2092px);
        max-width: 1660px;
    }
}

.vision_message_visual_item {
    position: absolute;
    overflow: hidden;
}

.vision_message_visual_item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.vision_message_visual_item-01 {
    display: block;
    width: min(29.76vw, 128px);
    height: min(41.39vw, 178px);
    top: 0;
    left: min(46.51vw, 200px);
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-01 {
        width: min(25.677vw, 493px);
        height: min(35.78vw, 687px);
        left: min(40.26vw, 773px);
    }
}

.vision_message_visual_item-02 {
    display: block;
    width: min(42.79vw, 184px);
    height: min(41.395vw, 178px);
    top: min(13.023vw, 56px);
    left: 0;
    z-index: 2;
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-02 {
        width: min(37.031vw, 711px);
        height: min(35.781vw, 687px);
        top: min(11.35vw, 218px);
    }
}

.vision_message_visual_item-03 {
    display: block;
    width: min(62.558vw, 269px);
    height: min(41.39vw, 178px);
    top: min(45.116vw, 194px);
    left: min(33.953vw, 146px);
    z-index: 1;
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-03 {
        width: min(54.114vw, 1039px);
        height: min(35.781vw, 687px);
        top: min(39.0625vw, 750px);
        left: min(29.32vw,563px);
    }
}

.vision_message_visual_item-04 {
    display: block;
    width: min(20vw, 86px);
    height: min(30vw, 129px);
    top: min(72.558vw, 312px);
    left: min(10.232vw, 44px);
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-04 {
        width: min(17.448vw, 335px);
        height: min(25.937vw, 498px);
        top: min(62.76vw, 1205px);
        left: min(8.75vw, 168px);
    }
}

.vision_message_visual_item-05 {
    display: block;
    width: min(32.79vw, 141px);
    height: min(22.093vw, 95px);
    top: min(90vw, 387px);
    left: min(67.209vw, 289px);
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-05 {
        width: min(28.437vw, 546px);
        height: min(18.95vw, 364px);
        top: min(77.86vw, 1495px);
        left: min(58.02vw, 1114px);
    }
}

.vision_message_visual_item-06 {
    display: block;
    width: min(23.721vw, 102px);
    height: min(29.767vw, 128px);
    top: min(96.279vw, 414px);
    left: min(39.767vw, 171px);
}
@media screen and (min-width: 920px){
    .vision_message_visual_item-06 {
        width: min(20.416vw, 392px);
        height: min(25.729vw, 494px);
        top: min(83.22vw, 1598px);
        left: min(34.479vw, 662px);
    }
}

.vision_message_bottom {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: unset;
    gap: min(10.93vw, 47px);
    padding-top: min(21.395vw, 92px);
}
@media screen and (min-width: 920px){
    .vision_message_bottom {
        max-width: 32vw;
        gap: min(3.739vw, 60px);
        padding-top: min(11.302vw, 217px);
        margin: 0 auto;
    }
}

.vision_message_bottom_message {
    font-family: var(--font-serif);
    font-size: min(4.883vw, 21px);
    font-weight: 500;
    line-height: 1.8;
    white-space: nowrap;
}
@media screen and (min-width: 920px){
    .vision_message_bottom_message {
        font-size: min(1.875vw, 36px);
        line-height: 1.77;
    }
}

.vision_message_bottom_text {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(6.976vw, 30px);
    padding: 0 min(3.953vw, 17px) 0 0;
}
@media screen and (min-width: 920px){
    .vision_message_bottom_text {
        max-width: 32vw;
        gap: min(2.177vw, 40px);
        padding: 0;
        margin: 0 auto;
    }
}

.vision_message_bottom_text p {
    font-family: var(--font-serif);
    font-weight: 500;
    text-align: justify;
}

.vision_movie {
    padding-top: min(20.232vw, 87px);
}
@media screen and (min-width: 920px){
    .vision_movie {
        padding-top: min(9.16vw, 176px);
    }
}

.vision_movie_contents {
    width: 100%;
    height: 69.76vw;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
@media screen and (min-width: 920px){
    .vision_movie_contents {
        height: min(37.5vw, 720px);
        transition: all 0.4s cubic-bezier(0.18, 0.06, 0.23, 1);
    }
}

@media screen and (min-width: 920px){
    .vision_movie_contents::after {
        content: "";
        position: absolute;
        background-color: rgba(0, 0, 0, 0.2);
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        mix-blend-mode: multiply;
        z-index: 1;
        opacity: 0;
        transition: all 0.4s cubic-bezier(0.18, 0.06, 0.23, 1);
    }
}

@media screen and (min-width: 920px){
    .vision_movie_contents:hover::after {
        opacity: 1;
    }
}

.vision_movie_bg {
    display: block;
    width: 100%;
    height: 69.76vw;
    overflow: hidden;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
}
@media screen and (min-width: 920px){
    .vision_movie_bg {
        height: min(37.5vw, 720px);
    }
}

.vision_movie_bg img {
    width: 100%;
    height: 100%;
}

.vision_movie_circle {
    width: min(30.465vw, 131px);
    height: min(30.465vw, 131px);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    border: 1px solid #ffffff;
}
@media screen and (min-width: 920px){
    .vision_movie_circle {
        width: min(8.802vw, 169px);
        height: min(8.802vw, 169px);
        position: relative;
        z-index: 2;
    }
}

.vision_movie_circle_inner {
    width: fit-content;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
@media screen and (min-width: 920px){
    .vision_movie_circle_inner {
        gap: clamp(0.5rem, 0.392rem + 0.4vw, 0.875rem);
    }
}

.vision_movie_circle_tri {
    width: min(5.814vw, 25px);
    height: min(4.651vw, 20px);
    position: relative;
    display: flex;
    margin-right: -5px;
}
@media screen and (min-width: 920px){
    .vision_movie_circle_tri {
        width: min(1.66vw, 32px);
        height: min(1.406vw, 27px);
    }
}

.vision_movie_circle_tri img {
    width: 100%;
    height: 100%;
}

.vision_movie_circle_inner p {
    font-size: 11px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #ffffff;
}
@media screen and (min-width: 920px){
    .vision_movie_circle_inner p {
        font-size: clamp(0.625rem, 0.607rem + 0.07vw, 0.688rem);
    }
}

.modalArea {
    display: none;
    position: fixed;
    z-index: 6000;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.modalBg {
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.86);
}

.modalWrapper {
    width: 100%;
    height: 56.279vw;
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
}
@media screen and (min-width: 920px){
    .modalWrapper {
        width: min(50vw, 960px);
        height: min(28.125vw, 540px);
    }
}

.modalContents, .modalContents iframe {
    width: 100%;
    height: 100%;
}

.closeModal {
    width: fit-content;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    position: absolute;
    top: min(4.348vw, 18.7px);
    right: min(4.651vw, 20px);
    cursor: pointer;
}
@media screen and (min-width: 920px){
    .closeModal {
        flex-direction: row-reverse;
        gap: min(0.781vw, 15px);
        top: min(2.74vw, 52.7px);
        right: min(2.83vw, 54.4px);
    }
}

.closeModal_icon {
    width: min(5.348vw, 23px);
    height: min(5.348vw, 23px);
    display: flex;
    position: relative;
}
@media screen and (min-width: 920px){
    .closeModal_icon {
        width: min(1.40625vw, 27px);
        height: min(1.40625vw, 27px);
    }
}

.closeModal_icon img {
    width: 100%;
    height: 100%;
}

.closeModal_catch {
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #ffffff;
}
@media screen and (min-width: 920px){
    .closeModal_catch {
        font-size: 11px;
    }
}

.vision_contents {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min(27.906vw, 120px);
    padding-top: min(20.209vw, 86.9px);
}
@media screen and (min-width: 920px){
    .vision_contents {
        gap: min(10.625vw, 204px);
        padding-top: min(10.468vw, 201px);
    }
}

.vision_contents_item {
    width: 100%;
    /*overflow: hidden;*/
}

.vision_contents_item .container-base {
    padding: 0;
}
@media screen and (min-width: 920px){
    .vision_contents_item .container-base {
        padding: 0 min(3.0208vw, 58px);
    }
}

.vision_contents_item_head {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 13px;
    margin: 0 auto min(8.139vw, 35px);
}
@media screen and (min-width: 920px){
    .vision_contents_item_head {
        width: 100%;
        height: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: min(2.135vw, 41px);
        margin: 0 auto min(4.0416vw, 77.6px);
    }
}

.vision_contents_item_icon {
    width: fit-content;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min(4.186vw, 18px);
}
@media screen and (min-width: 920px){
    .vision_contents_item_icon {
        gap: min(1.406vw, 27px);
    }
}

.vision_contents_item_icon span {
    width: 1px;
    height: min(25.79vw, 110.9px);
    background-color: #707070;
}
@media screen and (min-width: 920px){
    .vision_contents_item_icon span {
        height: min(11.997vw, 230.35px);
    }
}

.vision_contents_item_number {
    font-family: var(--font-catch);
    font-style: italic;
    font-size: min(3.255vw, 14px);
    line-height: 1;
    letter-spacing: 0.05em;
    text-align: center;
}
@media screen and (min-width: 920px){
    .vision_contents_item_number {
        font-size: min(0.9375vw, 18px);
    }
}

.vision_contents_item_title {
    font-family: var(--font-serif);
    font-size: min(4.186vw, 18px);
    font-weight: 500;
    line-height: 1.7;
    text-align: center;
}
@media screen and (min-width: 920px){
    .vision_contents_item_title {
        font-size: min(1.25vw, 24px);
        line-height: 1.83;
    }
}

.vision_contents_item_thumb {
    width: 100%;
    height: 62.79vw;
    overflow: hidden;
}
@media screen and (min-width: 920px){
    .vision_contents_item_thumb {
        height: min(42.7083vw, 820px);
    }
}

.vision_contents_item_thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.vision_contents_item_textArea {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(7.441vw, 32px);
    padding: min(12.79vw, 55px) min(100.069vw, 24px) 0;
}
@media screen and (min-width: 920px){
    .vision_contents_item_textArea {
        max-width: 32vw;
        gap: min(3.739vw, 60px);
        padding: min(8.854vw, 170px) 0 0;
        margin: 0 auto;
    }
}

.vision_contents_item_catch {
    font-family: var(--font-serif);
    font-size: min(5.116vw, 22px);
    font-weight: 500;
    white-space: nowrap;
}
@media screen and (min-width: 920px){
    .vision_contents_item_catch {
        font-size: min(1.875vw, 36px);
        line-height: 1.77;
        white-space: nowrap;
        letter-spacing: 0.04em;
    }
}

.vision_contents_item_text {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(8.604vw, 37px);
}
@media screen and (min-width: 920px){
    .vision_contents_item_text {
        gap: min(2.177vw, 40px);
    }
}

.vision_contents_item_text p {
    font-family: var(--font-serif);
    font-weight: 500;
}

.vision_contents_item_carousel {
    width: 100%;
    padding-top: min(16.744vw, 72px);
}
@media screen and (min-width: 920px){
    .vision_contents_item_carousel {
        padding-top: min(8.854vw, 170px);
    }
}

.vision_contents_item_carousel .swiper-wrapper {
    transition-timing-function: linear;
}

.vision_contents_item_carousel .swiper-slide {
    width: min(86.04vw, 370px);
    height: min(54.418vw, 234px);
    margin-right: 4px;
}
@media screen and (min-width: 920px){
    .vision_contents_item_carousel .swiper-slide {
        width: min(56.77vw, 1090px);
        height: min(35.93vw, 690px);
        margin-right: 8px;
    }
}

.vision_contents_item_slide {
    overflow: hidden;
}

.vision_contents_item_slide,
.vision_contents_item_slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.vision_summary {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(16.744vw, 72px);
    padding-top: min(22.79vw, 98px);
    margin-bottom: min(16.744vw, 72px);
}
@media screen and (min-width: 920px){
    .vision_summary {
        gap: min(6.71vw, 129px);
        padding-top: min(9.5vw, 182.4px);
        margin-bottom: min(9.427vw, 181px);
    }
}

.vision_summary_textArea {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(11.162vw, 48px);
}
@media screen and (min-width: 920px){
    .vision_summary_textArea {
        max-width: 32vw;
        gap: min(5.76vw, 110.6px);
        margin: 0 auto;
    }
}

.vision_summary_text {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: min(7.441vw, 32px);
}
@media screen and (min-width: 920px){
    .vision_summary_text {
        gap: min(2.177vw, 40px);
    }
}

.vision_summary_text p {
    font-family: var(--font-serif);
    font-weight: 500;
    text-align: justify;
}

.vision_summary_catch {
    font-family: var(--font-serif);
    font-size: min(8.139vw, 35px);
    font-weight: 500;
    line-height: 1.62;
}
@media screen and (min-width: 920px){
    .vision_summary_catch {
        font-size: min(3.072vw, 59px);
    }
}

.vision_summary_thumb {
    display: block;
    width: 100%;
    height: 54.418vw;
    margin: 0 auto;
}
@media screen and (min-width: 920px){
    .vision_summary_thumb {
        width: min(56.77vw, 1090px);
        height: min(35.9375vw, 690px);
    }
}

.vision_summary_thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}