section .inner {
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
}

section.visual {
    z-index: 100;
    width: 100%;
    height: auto;
    overflow: visible;
}

section.visual .heading {
    position: static;
    align-items: center;
    justify-content: center;
    max-width: 100%;
    height: 100vh;
    padding: 0 7.2rem;
    font-size: 6rem;
    text-align: center;
    color: var(--white-color);
    transform: none;
}

section.visual .heading .txt-line:nth-of-type(1) .txt-line {
    display: inline;
}

section.visual .bg {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    background: url("/assets/images/main/bg_visual2.jpg") 50% 50%/cover no-repeat;
    transform-origin: 40% center;
}

section.visual .card-list {
    position: relative;
    z-index: 100;
    width: 100%;
    max-width: var(--content-max-width);
    padding: 0 3.2rem;
    transform: translate(0px, 60%);
}

section.visual .card-list ul {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-bottom: 1.2rem;
    gap: 2.4rem;
}

section.visual .card-list li {
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 45rem;
    padding: 4.8rem 0;
    border-radius: 1.2rem;
    box-sizing: border-box;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.12);
    backdrop-filter: blur(2.4rem);
    gap: 1.2rem;
}

section.visual .card-list li span {
    display: flex;
    align-items: baseline;
    height: 12rem;
    font-size: 9.6rem;
    font-weight: 700;
    color: var(--white-color);
    gap: 0.8rem;
}

section.visual .card-list li span small {
    font-size: 2.4rem;
}

section.visual .card-list li .desc {
    font-size: 1.6rem;
    line-height: 2.4rem;
    color: var(--white-color);
}

section.visual .card-list .ref {
    text-align: right;
}

section.between {
    background-color: #B30635;
}

section.between .inner {
    min-height: 50vh;
}

section.section1 {
    text-align: center;
    color: var(--white-color);
    background-color: #B30635;
}

section.section1 .inner {
    min-height: 100vh;
}

section.section1 .desc-large {
    margin: 7.2rem 0;
    color: inherit;
}

section.section1 .bg {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    width: 100%;
    max-width: 113.4rem;
    transform: translate(-50%, -50%);
}

section.section2 {
    background-color: var(--bg-color-2);
}

section.section2 .inner {
    min-height: 100vh;
}

section.section2 .title {
    width: 105%;
    text-align: center;
}

section.section2 ul {
    position: relative;
    width: 100%;
    height: 44rem;
    margin-top: 7.2rem;
    opacity: 0;
    transform: translate3d(0, 50%, 0);
}

section.section2 ul li {
    position: absolute;
    top: 0;
    left: 50%;
    display: flex;
    align-items: center;
    width: 100%;
    border-radius: 1.2rem;
    background-color: var(--white-color);
    overflow: hidden;
    transform: translateX(-50%);
    transform-origin: top center;
}

section.section2 ul li:not(:first-child) {
    opacity: 0;
}

section.section2 ul li:first-child .cont,
section.section2 ul li:last-child .cont {
    flex-flow: row-reverse;
}

section.section2 ul .cont {
    display: flex;
    width: 100%;
}

section.section2 ul .cont>* {
    width: 50%;
}

section.section2 ul .txt-group {
    display: flex;
    flex-flow: column;
    justify-content: center;
    padding: 4.8rem;
    gap: 2.4rem;
}

section.section2 ul .img {
    position: relative;
    overflow: hidden;
    aspect-ratio: 72/55;
}

section.section2 ul .img img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

section.section2 .btn-view {
    margin-top: 12rem;
}

section.section3 {
    background-color: var(--white-color);
}

section.section3 .inner {
    min-height: 100vh;
}

section.section3 .swiper {
    width: 100%;
    overflow: visible;
}

section.section3 ul {
    display: flex;
    justify-content: flex-start;
    margin: 7.2rem 0;
    padding-bottom: 2.4rem;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 2.4rem;
}

section.section3 ul::-webkit-scrollbar {
    width: 0.3rem;
    height: 0.3rem;
}

section.section3 ul::-webkit-scrollbar-thumb {
    border-radius: 2rem;
    background: #BBBBBB;
}

section.section3 ul::-webkit-scrollbar-track {
    background: rgba(187, 187, 187, 0.5);
}

section.section3 ul img {
    max-width: 36.8rem;
    border-radius: 1.2rem;
}

section.section3 ul li {
    position: relative;
    flex: 1 0 36.8rem;
}

section.section3 ul a {
    position: relative;
    display: block;
    border-radius: 1.2rem;
    overflow: hidden;
}

section.section3 ul a:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 15.8rem;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, rgba(17, 22, 26, 0) 0%, rgba(17, 22, 26, 0.84) 100%);
}

section.section3 ul .txt-group {
    position: absolute;
    right: 2.4rem;
    bottom: 2.4rem;
    left: 2.4rem;
    z-index: 100;
    display: flex;
    flex-flow: column;
    font-size: 1.8rem;
    font-weight: 400;
    color: var(--white-color);
    gap: 0.4rem;
}

section.section3 ul .txt-group strong {
    font-size: 2.6rem;
    font-weight: 700;
}

section.section3 ul .txt-group strong span {
    font-size: 1.8rem;
    font-weight: 400;
}

section.section4 {
    background-color: var(--bg-color-2);
}

section.section4 .inner {
    justify-content: flex-start;
    height: auto;
    min-height: auto;
    padding: 26.2rem 3.2rem;
}

section.section4 ul {
    margin-top: 7.2rem;
}

section.section4 ul li {
    display: flex;
    border-radius: 1.2rem;
    background-color: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(48px);
    overflow: hidden;
}

section.section4 ul li:not(:first-child) {
    margin-top: 7.2rem;
}

section.section4 ul li:first-child,
section.section4 ul li:last-child {
    flex-flow: row-reverse;
}

section.section4 ul li>* {
    width: 50%;
    overflow: hidden;
}

section.section4 ul .txt-group {
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    padding: 4.8rem;
    background-color: var(--white-color);
    gap: 2.4rem;
}

section.section4 ul .txt-group .desc {
    color: var(--gray-color-5);
}

section.section5 {
    background: var(--white-color);
}

section.section5 .inner {
    min-height: 100vh;
}

section.section5 .notice-list {
    margin-top: 7.2rem;
}

section.section5 .notice-list [class*=tag] {
    padding: 0;
    color: var(--gray-color-4);
    background-color: transparent;
}

section.section5 .btn-view {
    margin-top: 7.2rem;
}

section.section6 {
    color: var(--white-color);
    background: url("/assets/images/main/bg_hire.jpg") 50% 50%/cover no-repeat;
}

section.section6 .inner {
    min-height: 100vh;
}

section.section6 ul {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    margin-top: 7.2rem;
    gap: 2.4rem;
}

section.section6 ul li {
    flex: 1 1 35rem;
    padding: 4.8rem;
    border-radius: 1.2rem;
    box-sizing: border-box;
}

section.section6 ul li:first-child {
    background-color: var(--primary-color);
}

section.section6 ul li:first-child a {
    color: var(--white-color);
}

section.section6 ul li:first-child a:focus {
    outline-color: var(--white-color);
}

section.section6 ul li:last-child {
    background-color: var(--white-color);
}

section.section6 ul li:last-child a {
    color: var(--bg-color-5);
}

section.section6 ul a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2.4rem;
}

section.section6 ul .txt-group {
    display: flex;
    flex: 1;
    flex-flow: column;
    font-size: 1.6rem;
    gap: 1.2rem;
}

section.section6 ul .txt-group strong {
    font-size: 2.8rem;
}

section.section6 ul .move {
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 50%;
    background-color: var(--white-color);
}

section.section6 ul .move.white {
    background-color: var(--primary-color);
}

section.section6 ul .move.white .arrow {
    background-color: var(--white-color);
}

section.section6 ul .move .arrow {
    display: inline-block;
    width: 100%;
    height: 100%;
    background-color: var(--primary-color);
    mask-image: url("/assets/images/icons/icon_arrow_circle2.svg");
    mask-repeat: no-repeat;
    mask-position: 50% 50%;
    mask-size: contain;
}

section.section6 ul .txt-mo {
    display: none;
}

@media screen and (max-width: 1024px) {
    section.visual .heading {
        font-size: 4.8rem;
    }

    section.visual .heading span:nth-of-type(1) {
        display: flex;
        flex-flow: column;
        align-items: center;
    }

    section.visual .bg {
        background-image: url("/assets/images/main/bg_m_visual.jpg");
        background-position: 100% 50%;
        transform-origin: 100% center;
    }

    section.visual .card-list {
        transform: translate(0px, 60%);
    }

    section.visual .card-list ul {
        flex-flow: column;
    }

    section.visual .card-list ul li {
        max-width: 100%;
        padding: 4.8rem 6.2rem;
        gap: 0;
    }

    section.visual .card-list ul li span {
        height: 9rem;
        font-size: 7.2rem;
    }

    section.visual .card-list ul li span small {
        font-size: 2rem;
    }

    section.section1 .bg {
        max-width: 81.5%;
    }

    section.section2 ul {
        display: flex;
        height: auto;
        opacity: 1;
        transform: none;
        gap: 4rem;
    }

    section.section2 ul li {
        position: static;
        min-width: 47.4rem;
        max-width: 62.4rem;
        transform: none;
    }

    section.section2 ul li:not(:first-child) {
        opacity: 1;
    }

    section.section2 ul .cont {
        flex-flow: column-reverse !important;
        justify-content: flex-end;
        height: 100%;
    }

    section.section2 ul .cont>* {
        width: 100%;
    }

    section.section2 ul .txt-group {
        padding: 2.4rem;
    }

    section.section2 ul .img {
        aspect-ratio: 208/95;
    }

    section.section2 .btn-view {
        margin-top: 7.2rem;
    }

    section.section3 .title {
        text-align: center;
    }

    section.section3 ul {
        justify-content: normal;
        overflow: visible;
        gap: 0;
    }

    section.section3 ul li {
        flex: none;
        transition: transform 300ms ease;
        transform: scale(0.8) !important;
    }

    section.section3 ul li.swiper-slide-active {
        transform: scale(1) !important;
    }

    section.section3 ul .txt-group {
        bottom: 2.4rem;
        left: 2.4rem;
        font-size: 1.6rem;
    }

    section.section3 ul .txt-group strong {
        font-size: 2.2rem;
    }

    section.section4 ul li {
        flex-flow: column-reverse !important;
    }

    section.section4 ul li>* {
        width: 100%;
    }

    section.section4 ul .txt-group {
        padding: 2.4rem;
        gap: 1.6rem;
    }

    section.section6 .title {
        text-align: center;
    }

    section.section6 ul li {
        padding: 2.4rem;
    }

    section.section6 ul .txt-group {
        font-size: 1.6rem;
    }

    section.section6 ul .txt-group strong {
        font-size: 2.4rem;
    }
}

@media screen and (max-width: 768px) {
    section.visual {
        background-color: #B30635;
    }

    section.visual .bg {
        background-position: 100% 0%;
        background-size: contain;
    }

    section.visual .heading {
        padding: 0 2.4rem;
        font-size: 3.6rem;
    }

    section.visual .card-list {
        padding: 0 2.4rem;
        transform: translate(0px, 30%);
    }

    section.visual .card-list ul li {
        padding: 2.4rem 6.2rem;
    }

    section.section2 .title {
        font-size: 2.15rem;
    }

    section.section2 ul {
        margin-top: 3.6rem;
    }

    section.section3 ul a:after {
        height: 10rem;
    }

    section.section3 ul .txt-group strong {
        font-size: 1.8rem;
    }

    section.section3 ul .txt-group strong span {
        font-size: 1.4rem;
    }

    section.section3 ul .txt-group span {
        font-size: 1.4rem;
    }

    section.section4 ul li:not(:first-child) {
        margin-top: 4.8rem;
    }

    section.section6 ul .txt-group {
        font-size: 1.4rem;
    }

    section.section6 ul .txt-group strong {
        font-size: 2.2rem;
    }

    section.section6 ul .txt-pc {
        display: none;
    }

    section.section6 ul .txt-mo {
        display: block;
    }
}

@media screen and (max-width: 600px) {
    section.visual .heading span {
        display: inline;
    }
}

@media screen and (max-width: 480px) {
    section.section2 ul li {
        min-width: 100%;
    }
}

@media screen and (max-width: 375px) {
    section.section2 ul .img {
        aspect-ratio: 13/9;
    }
}