@charset "UTF-8";
/*==================================================================================================
	TOP
==================================================================================================*/
#top .mv {
    padding-top: 150px;
    padding-left: 7.5%;
}
@media (max-width: 1280px) {
    #top .mv {
        padding-top: clamp(85px, 12vw, 120px);
    }
}
#top .mv_inner {
    position: relative;
}
#top .mv_img {
    display: flex;
    flex-wrap: wrap;
    -webkit-clip-path: inset(0 0 round min(150px, 10vw) 0 0 0);
    clip-path: inset(0 0 round min(150px, 10vw) 0 0 0);
}
#top .mv .img_slide {
    width: 50%;
    height: calc(100svh - clamp(85px, 12vw, 120px));
    opacity: 0;
    transition: opacity 2s, translate 1.5s;
    translate: 0 -5%;
}
#top .mv .img_slide.-active {
    opacity: 1;
    translate: 0 0;
}
@media (max-width: 840px) {
    #top .mv .img_slide {
        width: 100%;
        height: calc((100svh - clamp(85px, 12vw, 120px)) / 2);
    }
}
#top .mv .img_list {
    width: 50%;
    height: calc(100svh - 150px);
}
@media (max-width: 1280px) {
    #top .mv .img_list {
        height: calc(100svh - clamp(85px, 12vw, 120px));
    }
}
@media (max-width: 840px) {
    #top .mv .img_list {
        width: 100%;
        height: calc((100svh - clamp(85px, 12vw, 120px)) / 2);
    }
}
#top .mv .img_item {
    height: calc(100svh - 150px);
}
@media (max-width: 1280px) {
    #top .mv .img_item {
        height: calc(100svh - clamp(85px, 12vw, 120px));
    }
}
@media (max-width: 840px) {
    #top .mv .img_item {
        height: calc((100svh - clamp(85px, 12vw, 120px)) / 2);
    }
}
#top .mv .img_item img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}
#top .mv_catch {
    position: absolute;
    bottom: 7.5%;
    right: 2.5%;
    display: flex;
    flex-direction: column;
    gap: min(30px, 2.5vw) 0;
}
@media (max-width: 840px) {
    #top .mv_catch {
        bottom: 10%;
        right: 5%;
    }
}
#top .mv_catch .txts {
    display: flex;
}
#top .mv_catch .txts:nth-child(1) {
    margin-left: -10%;
}
#top .mv_catch .txts img {
    height: 6.75vw;
    max-height: 130px;
    width: auto;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
    -webkit-filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.5));
    filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.5));
    opacity: 0;
    transition: opacity 1s, translate 1.5s cubic-bezier(0.16, 1, 0.3, 1), -webkit-transform 2s cubic-bezier(0.16, 1, 0.3, 1);
    transition: opacity 1s, transform 2s cubic-bezier(0.16, 1, 0.3, 1), translate 1.5s cubic-bezier(0.16, 1, 0.3, 1);
    transition: opacity 1s, transform 2s cubic-bezier(0.16, 1, 0.3, 1), translate 1.5s cubic-bezier(0.16, 1, 0.3, 1), -webkit-transform 2s cubic-bezier(0.16, 1, 0.3, 1);
    -webkit-transform: scale3d(0, 1.25, 1.5);
    transform: scale3d(0, 1.25, 1.5);
    translate: 50% 0;
}
#top .mv_catch .txts img.-active {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
    translate: 0 0;
}
@media (max-width: 840px) {
    #top .mv_catch .txts img {
        height: 10vw;
    }
}
#top .concept_inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    z-index: 10;
}
@media (max-width: 840px) {
    #top .concept_inner {
        flex-direction: column-reverse;
    }
}
#top .concept_img {
    width: 100vw;
    aspect-ratio: 1/1;
    margin-left: calc(50% - 50vw);
    position: relative;
}
@media (max-width: 840px) {
    #top .concept_img {
        width: 90%;
        margin-top: clamp(50px, 8vw, 80px);
    }
}
#top .concept_img .img {
    position: absolute;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: min(10px, 2.5vw);
}
#top .concept_img .img:nth-child(1) {
    top: 0;
    left: 0;
    width: 80%;
    aspect-ratio: 4/3;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    background-image: url(../img/top/concept_01.jpg);
}
#top .concept_img .img:nth-child(2) {
    bottom: 0;
    right: 0;
    width: 50%;
    aspect-ratio: 1/1;
    background-image: url(../img/top/concept_02.jpg);
}
#top .concept_copy {
    width: 130%;
    padding-left: 15%;
    margin-top: 10%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    display: flex;
    flex-direction: column;
    gap: 0.5em 0;
    font-size: calc(clamp(4rem, 5.2vw, 7.2rem) * 0.75);
}
@media (max-width: 840px) {
    #top .concept_copy {
        width: 100%;
        padding-left: 10%;
        margin-top: 0;
    }
}
@media (max-width: 540px) {
    #top .concept_copy {
        font-size: 7vw;
    }
}
#top .concept_copy .txt {
    line-height: 1.35;
    letter-spacing: 0.015em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .concept_copy .txt.-active {
    opacity: 1;
}
#top .concept_copy .txt.-active span {
    translate: 0 0;
}
#top .concept_copy .txt span {
    line-height: inherit;
    display: inline-block;
    translate: 0 1em;
    transition: translate 1s;
}
#top .concept_txtanim {
    white-space: nowrap;
    position: relative;
    z-index: 15;
    margin-top: clamp(50px, 8vw, 80px);
    margin-left: -7.5%;
    margin-top: -7.5%;
}
@media (max-width: 1600px) {
    #top .concept_txtanim {
        margin-top: -2.5%;
    }
}
@media (max-width: 840px) {
    #top .concept_txtanim {
        margin-top: clamp(50px, 8vw, 80px);
    }
}
#top .concept_txtanim .txtanim_img {
    margin-left: auto;
}
#top .concept_txtanim .txtanim_inner {
    display: inline-block;
    white-space: nowrap;
    -webkit-animation: scrollText 120s linear infinite;
    animation: scrollText 120s linear infinite;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .concept_txtanim .txtanim_inner.-active {
    opacity: 1;
}
#top .concept_txtanim .txtanim_inner.-active span {
    translate: 0 0;
}
#top .concept_txtanim .txtanim_inner span {
    display: inline-block;
    padding-right: 15px;
    font-weight: 500;
    font-size: min(10vw, 15rem);
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1;
    color: #004ea2;
    translate: 0 1em;
    transition: translate 1s;
}
@media (max-width: 840px) {
    #top .concept_txtanim .txtanim_inner span {
        font-size: 15vw;
    }
}
@-webkit-keyframes scrollText {
    0% {
        -webkit-transform: translateX(0%);
        transform: translateX(0%);
    }
    100% {
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
}
@keyframes scrollText {
    0% {
        -webkit-transform: translateX(0%);
        transform: translateX(0%);
    }
    100% {
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
}
#top .concept_txtanim .txtanim_img {
    width: 40%;
    aspect-ratio: 2/1;
    z-index: 10;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-image: url(../img/top/txtanim_img.jpg);
    border-radius: min(10px, 2.5vw);
    margin-bottom: -2.5%;
}
@media (max-width: 840px) {
    #top .concept_txtanim .txtanim_img {
        width: 70%;
    }
}
#top .concept_deco {
    position: absolute;
    right: -5%;
    top: 25%;
    z-index: 5;
    width: 55%;
    mix-blend-mode: color-dodge;
    opacity: 0;
    translate: 0 20%;
    transition: 0.5s opacity, 2s translate;
}
@media (max-width: 840px) {
    #top .concept_deco {
        top: 5%;
        width: 90%;
    }
}
#top .concept_deco.-active {
    opacity: 1;
    translate: 0 0;
}
#top .news_inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: auto 10% 1fr;
    grid-template-columns: auto 1fr;
    -ms-grid-rows: auto 0 auto;
    grid-template-rows: auto auto;
    grid-template-areas: "secttl list" "morebtn list";
    gap: 0 10%;
    align-items: start;
}
@media (max-width: 840px) {
    #top .news_inner {
        display: flex;
        flex-direction: column;
    }
}
#top .news_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#top .news_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #top .news_secttl .ja {
        font-size: 4.5vw;
    }
}
#top .news_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .news_secttl .en.-active {
    opacity: 1;
}
#top .news_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #top .news_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#top .news_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#top .news_secttl {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    grid-area: secttl;
}
#top .news_secttl .en {
    margin-bottom: 0;
}
@media (max-width: 540px) {
    #top .news_secttl .en {
        margin-bottom: 0.5em;
    }
}
#top .news_list {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    grid-area: list;
    grid-row: 1/4;
}
@media (max-width: 840px) {
    #top .news_list {
        width: 100%;
    }
}
#top .news_morebtn {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    grid-area: morebtn;
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    margin-top: 1.5em;
    display: flex;
    align-items: center;
    gap: 0.5em;
}
#top .news_morebtn span {
    font-size: inherit;
    transition: color 0.5s;
}
#top .news_morebtn::after {
    content: "";
    background-image: url(../img/top/news_btn.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 1.25em;
    height: 1.25em;
    transition: scale 0.5s;
}
#top .news_morebtn:hover span {
    color: #004ea2;
}
#top .news_morebtn:hover::after {
    scale: 1.25;
}
#top .recruit {
    margin-bottom: 0;
    z-index: 15;
}
#top .recruit_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
@media (max-width: 840px) {
    #top .recruit_inner {
        flex-direction: column;
        align-items: flex-start;
    }
}
#top .recruit_img {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    position: relative;
    -webkit-clip-path: inset(0 0 0 0 round 0 50vw 50vw 0);
    clip-path: inset(0 0 0 0 round 0 50vw 50vw 0);
    height: auto;
    aspect-ratio: 1.5/1;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-image: url(../img/top/recruit.jpg);
}
@media (max-width: 840px) {
    #top .recruit_img {
        width: 100%;
    }
}
#top .recruit_content {
    padding-left: 7.5%;
}
@media (max-width: 840px) {
    #top .recruit_content {
        padding-left: 0;
        margin-top: clamp(50px, 8vw, 80px);
        margin-left: auto;
    }
}
#top .recruit_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#top .recruit_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #top .recruit_secttl .ja {
        font-size: 4.5vw;
    }
}
#top .recruit_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .recruit_secttl .en.-active {
    opacity: 1;
}
#top .recruit_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #top .recruit_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#top .recruit_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#top .recruit_btns {
    display: flex;
    flex-direction: column;
    gap: 1.25em 0;
}
#top .recruit_btn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#top .recruit_btn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#top .recruit_btn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#top .recruit_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#top .recruit_btn:hover {
    background-color: #004ea2;
}
#top .recruit_btn:hover span {
    color: #fff;
}
#top .recruit_btn:hover::before {
    right: 0.85em;
}
#top .recruit_btn:hover::after {
    scale: 1;
}
#top .recruit_btn {
    width: 15em;
}
@media (max-width: 840px) {
    #top .recruit_btn {
        width: 100%;
    }
}
#top .works {
    background-image: url(../img/top/works_bg.jpg);
    background-size: 50px;
    background-position: center;
    background-repeat: repeat;
    padding: clamp(80px, 12vw, 200px) 5%;
    margin: calc(clamp(80px, 12vw, 200px) * 0.25) auto;
}
@media (max-width: 840px) {
    #top .works {
        padding: calc(clamp(80px, 12vw, 200px) * 1.75) 5%;
    }
}
#top .works::before, #top .works::after {
    left: 50%;
    translate: -50% 0;
    width: 150%;
    height: 50%;
    background: #fff;
    -webkit-filter: blur(20px);
    filter: blur(20px);
}
#top .works::before {
    content: "";
    position: absolute;
    top: -50px;
    background: linear-gradient(0deg, rgba(242, 242, 242, 0) 0%, #f2f2f2 80%, #f2f2f2 100%);
}
#top .works::after {
    content: "";
    position: absolute;
    bottom: -50px;
    background: linear-gradient(180deg, rgba(242, 242, 242, 0) 0%, #f2f2f2 80%, #f2f2f2 100%);
}
#top .works_inner {
    z-index: 10;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: auto 1fr auto;
    grid-template-columns: auto 1fr auto;
    -ms-grid-rows: auto auto;
    grid-template-rows: auto auto;
    grid-template-areas: "secttl . morebtn" "list list list";
    align-items: start;
}
@media (max-width: 840px) {
    #top .works_inner {
        display: flex;
        flex-direction: column;
    }
}
#top .works_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #fff;
}
#top .works_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #fff;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #top .works_secttl .ja {
        font-size: 4.5vw;
    }
}
#top .works_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .works_secttl .en.-active {
    opacity: 1;
}
#top .works_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #top .works_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#top .works_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #fff;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#top .works_secttl {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    grid-area: secttl;
}
#top .works_secttl .en {
    margin-bottom: 0;
}
@media (max-width: 840px) {
    #top .works_secttl .en {
        margin-bottom: 0.75em;
    }
}
@media (max-width: 540px) {
    #top .works_secttl .en {
        margin-bottom: 0.5em;
    }
}
#top .works_list {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    grid-area: list;
    margin-top: clamp(50px, 8vw, 80px);
}
@media (max-width: 840px) {
    #top .works_list {
        margin-top: 0;
    }
}
#top .works_morebtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #fff;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#top .works_morebtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #fff;
    transition: color 0.5s;
}
#top .works_morebtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #fff;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#top .works_morebtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #004ea2;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#top .works_morebtn:hover {
    background-color: #fff;
}
#top .works_morebtn:hover span {
    color: #004ea2;
}
#top .works_morebtn:hover::before {
    right: 0.85em;
}
#top .works_morebtn:hover::after {
    scale: 1;
}
#top .works_morebtn {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    grid-area: morebtn;
    margin-bottom: 0.25em;
    -ms-grid-row-align: end;
    align-self: end;
}
@media (max-width: 840px) {
    #top .works_morebtn {
        margin: calc(clamp(50px, 8vw, 80px) * 0.75) auto 0;
    }
}
#top .business {
    margin: clamp(80px, 12vw, 200px) auto 0;
}
#top .business_inner {
    display: flex;
    gap: 0 10%;
    align-items: center;
    z-index: 10;
}
@media (max-width: 840px) {
    #top .business_inner {
        flex-direction: column;
        align-items: start;
    }
}
#top .business_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#top .business_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #top .business_secttl .ja {
        font-size: 4.5vw;
    }
}
#top .business_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#top .business_secttl .en.-active {
    opacity: 1;
}
#top .business_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #top .business_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#top .business_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#top .business_content {
    background-color: #004ea2;
    color: #fff;
    margin-right: calc(50% - 50vw);
    border-radius: min(2.5vw, 30px) 0 0 min(2.5vw, 30px);
    padding: clamp(50px, 8vw, 80px) 0 clamp(50px, 8vw, 80px) min(10%, 50px);
    width: 100vw;
    position: relative;
    z-index: 10;
}
@media (max-width: 840px) {
    #top .business_content {
        padding: clamp(50px, 8vw, 80px) 0 clamp(50px, 8vw, 80px) min(5%, 50px);
        width: 105%;
    }
}
#top .business_img {
    -o-object-fit: cover;
    object-fit: cover;
    background-image: url(../img/top/business.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    aspect-ratio: 2/1;
    border-radius: 500px 0 0 500px;
    position: relative;
}
#top .business_copy {
    position: absolute;
    bottom: 0;
    right: 0.15em;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    text-align: right;
    display: block;
    color: #003771;
    font-size: 2.5vw;
    line-height: 1.15;
}
@media (max-width: 840px) {
    #top .business_copy {
        font-size: 6vw;
    }
}
#top .business_ttl {
    font-weight: 700;
    color: #fff;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    line-height: 1.35;
    margin-top: clamp(50px, 8vw, 80px);
    margin-bottom: 1em;
    padding-right: min(10%, 50px);
}
@media (max-width: 840px) {
    #top .business_ttl {
        padding-right: min(5%, 50px);
    }
}
#top .business_txt {
    padding-right: min(10%, 50px);
}
@media (max-width: 840px) {
    #top .business_txt {
        padding-right: min(5%, 50px);
    }
}
#top .business_morebtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#top .business_morebtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#top .business_morebtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#top .business_morebtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#top .business_morebtn:hover {
    background-color: #004ea2;
}
#top .business_morebtn:hover span {
    color: #fff;
}
#top .business_morebtn:hover::before {
    right: 0.85em;
}
#top .business_morebtn:hover::after {
    scale: 1;
}
#top .business_morebtn {
    position: absolute;
    left: 0;
    top: 60%;
    translate: 0 -50%;
    margin-top: clamp(50px, 8vw, 80px);
}
@media (max-width: 840px) {
    #top .business_morebtn {
        position: relative;
        margin: calc(clamp(50px, 8vw, 80px) * 0.75) auto 0;
        left: auto;
        top: auto;
        translate: 0 0;
    }
}
#top .business_deco.-deco_01 {
    position: absolute;
    width: min(0.75vw, 5px);
    height: 130%;
    rotate: 45deg;
    top: -80px;
    right: 0;
    translate: -50% 0;
    -webkit-transform-origin: left top;
    transform-origin: left top;
}
#top .business_deco.-deco_01::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #004ea2;
    transition: 2s height;
}
@media (max-width: 540px) {
    #top .business_deco.-deco_01::before {
        left: 20vw;
    }
}
#top .business_deco.-deco_01.-active::before {
    height: 100%;
}
#top .business_deco.-deco_02 {
    position: absolute;
    left: -25%;
    top: 50%;
    translate: 0 -50%;
    width: 40%;
    mix-blend-mode: color-dodge;
    -webkit-animation: pulse 5s ease-in-out infinite;
    animation: pulse 5s ease-in-out infinite;
}
@-webkit-keyframes pulse {
    0%, 100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
    50% {
        -webkit-transform: scale(1.25);
        transform: scale(1.25);
    }
}
@keyframes pulse {
    0%, 100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
    50% {
        -webkit-transform: scale(1.25);
        transform: scale(1.25);
    }
}
#top .slider {
    width: 115%;
    margin: clamp(80px, 12vw, 200px) -7.5%;
}
#top .slider_list {
    transition-timing-function: linear !important;
}
#top .slider_item {
    margin-left: 5%;
    width: 30vw;
}
@media (max-width: 840px) {
    #top .slider_item {
        width: 50vw;
    }
}
#top .slider_item img {
    border-radius: min(2.5vw, 20px);
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    aspect-ratio: 3/4;
}
#top .slider_item.-item01 {
    margin-top: 3.5%;
}
#top .slider_item.-item02 {
    width: 45vw;
    margin-top: 15%;
}
@media (max-width: 840px) {
    #top .slider_item.-item02 {
        width: 55vw;
    }
}
#top .slider_item.-item02 img {
    aspect-ratio: 4/3;
}
#top .slider_item.-item04 {
    margin-top: 10%;
}
#top .slider_deco {
    position: absolute;
    bottom: 0;
    left: 5%;
    width: 45%;
    z-index: 10;
    mix-blend-mode: multiply;
}
@media (max-width: 540px) {
    #top .slider_deco {
        width: 70%;
    }
}

/*==================================================================================================
	お知らせ
==================================================================================================*/
#news .article_date {
    font-size: 1.8rem;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    color: #004ea2;
}
#news .article_ttl {
    line-height: 1.35;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    border-bottom: 1px solid #004ea2;
    padding-bottom: 1em;
    margin-bottom: 1em;
}
#news .article_content img {
    margin: 1em auto;
    width: auto;
}
#news .article_content a {
    text-decoration: underline;
    color: #004ea2;
    display: inline-block;
}
#news .article_content a:hover {
    opacity: 0.7;
}
#news .article_backbtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#news .article_backbtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#news .article_backbtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#news .article_backbtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#news .article_backbtn:hover {
    background-color: #004ea2;
}
#news .article_backbtn:hover span {
    color: #fff;
}
#news .article_backbtn:hover::before {
    right: 0.85em;
}
#news .article_backbtn:hover::after {
    scale: 1;
}
#news .article_backbtn {
    display: block;
    margin: 2em auto 0;
}

/*==================================================================================================
	実績紹介
==================================================================================================*/
#works .archive_link {
    border: min(0.75vw, 3px) solid #004ea2;
}
#works .article_ttl {
    line-height: 1.35;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    font-weight: 700;
    color: #004ea2;
    margin-bottom: 1em;
    position: relative;
    padding-left: 0.75em;
}
#works .article_ttl::before {
    content: "";
    position: absolute;
    top: 55%;
    left: 0;
    translate: 0 -50%;
    width: 0.2em;
    height: 70%;
    background-color: #004ea2;
}
#works .article_img img {
    aspect-ratio: 16/9;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    border-radius: min(2.5vw, 7.5px);
}
#works .article_gallery {
    margin-top: 1.5em;
}
#works .article_gallery .gallery_list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75em 1.5%;
}
#works .article_gallery .gallery_item {
    width: 23.875%;
}
@media (max-width: 540px) {
    #works .article_gallery .gallery_item {
        width: 32.3333333333%;
    }
}
#works .article_gallery .gallery_item a {
    padding: 0;
    transition: 0.5s opacity;
}
#works .article_gallery .gallery_item a:hover {
    opacity: 0.7;
}
#works .article_gallery .gallery_item a img {
    aspect-ratio: 16/9;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    border-radius: min(2.5vw, 7.5px);
}
#works .article_txt {
    margin-top: 2.5em;
}
#works .article_txt img {
    margin: 1em auto;
    width: auto;
}
#works .article_txt a {
    text-decoration: underline;
    color: #004ea2;
    display: inline-block;
}
#works .article_txt a:hover {
    opacity: 0.7;
}
#works .article_backbtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#works .article_backbtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#works .article_backbtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#works .article_backbtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#works .article_backbtn:hover {
    background-color: #004ea2;
}
#works .article_backbtn:hover span {
    color: #fff;
}
#works .article_backbtn:hover::before {
    right: 0.85em;
}
#works .article_backbtn:hover::after {
    scale: 1;
}
#works .article_backbtn {
    display: block;
    margin: 2em auto 0;
}

/*==================================================================================================
	事業内容
==================================================================================================*/
#business .about_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
}
@media (max-width: 840px) {
    #business .about_inner {
        flex-direction: column;
        align-items: flex-start;
    }
}
#business .about_img {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    position: relative;
    -webkit-clip-path: inset(0 0 0 0 round 0 50vw 50vw 0);
    clip-path: inset(0 0 0 0 round 0 50vw 50vw 0);
    height: auto;
    background-image: url(../img/business/about.jpg);
    aspect-ratio: 2/1;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
@media (max-width: 1280px) {
    #business .about_img {
        aspect-ratio: 1/1;
    }
}
@media (max-width: 840px) {
    #business .about_img {
        aspect-ratio: 2/1;
        width: 100%;
    }
}
#business .about_content {
    padding-left: 7.5%;
    width: 100%;
}
@media (max-width: 840px) {
    #business .about_content {
        padding-left: 0;
        margin-top: clamp(50px, 8vw, 80px);
        margin-left: auto;
    }
}
#business .about_ttl {
    font-size: clamp(3.2rem, 4vw, 4.5rem);
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: 1em;
}
#business .about_subttl {
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: 1em;
    color: #fff;
    background-color: #004ea2;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 0.35em 0.5em;
}
#business .about_list {
    display: flex;
    flex-direction: column;
    gap: 0.5em 0;
}
#business .about_item {
    position: relative;
    padding-left: 0.75em;
    line-height: 1.35;
}
#business .about_item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
#business .about_copy {
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    display: block;
    color: #004ea2;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    line-height: 1.15;
    margin-top: 3em;
}
@media (max-width: 840px) {
    #business .about_copy {
        margin-top: 2em;
        font-size: 5vw;
    }
}
@media (max-width: 540px) {
    #business .about_copy {
        font-size: 7vw;
    }
}
#business .about_deco {
    position: absolute;
    right: -15%;
    top: 50%;
    translate: 0 -50%;
    width: 35%;
    mix-blend-mode: color-dodge;
    -webkit-animation: pulse 5s ease-in-out infinite;
    animation: pulse 5s ease-in-out infinite;
}
@media (max-width: 1280px) {
    #business .about_deco {
        width: 50%;
        top: 75%;
    }
}
@media (max-width: 540px) {
    #business .about_deco {
        width: 70%;
    }
}
@keyframes pulse {
    0%, 100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
    50% {
        -webkit-transform: scale(1.25);
        transform: scale(1.25);
    }
}
#business .drawing_inner {
    display: flex;
    flex-direction: column;
    gap: clamp(50px, 8vw, 80px) 0;
}
#business .drawing_content {
    display: flex;
    align-items: center;
    gap: 0 5%;
}
#business .drawing_content:nth-child(2) {
    flex-direction: row-reverse;
}
@media (max-width: 1280px) {
    #business .drawing_content:nth-child(2) {
        flex-direction: column;
    }
}
@media (max-width: 1280px) {
    #business .drawing_content {
        flex-direction: column;
        align-items: flex-start;
    }
}
#business .drawing_ttl {
    font-size: clamp(3.2rem, 4vw, 4.5rem);
    position: relative;
    padding-left: 0.75em;
    font-weight: 700;
    display: block;
    line-height: 1.35;
    white-space: nowrap;
}
@media (max-width: 1280px) {
    #business .drawing_ttl {
        margin-bottom: 0.5em;
    }
}
#business .drawing_ttl::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
#business .drawing_list {
    width: -webkit-fill-available;
    width: -moz-available;
    width: stretch;
    display: flex;
    flex-wrap: wrap;
    gap: min(5vw, 30px) 1.5%;
}
@media (max-width: 840px) {
    #business .drawing_list {
        gap: min(5vw, 30px) 2.5%;
    }
}
#business .drawing_item {
    width: 32.3333333333%;
    background-color: #fff;
    padding: min(2.5vw, 30px) min(2.5vw, 30px);
    border-radius: min(2.5vw, 10px);
    position: relative;
}
@media (max-width: 840px) {
    #business .drawing_item {
        width: 48.75%;
    }
}
@media (max-width: 540px) {
    #business .drawing_item {
        width: 100%;
    }
}
#business .drawing_item img {
    -o-object-fit: cover;
    object-fit: cover;
    aspect-ratio: 1/1;
    -o-object-position: center;
    object-position: center;
    border-radius: min(2.5vw, 10px);
}
#business .drawing_btn {
    width: 3.5em;
    height: 3.5em;
    border: none;
    position: absolute;
    bottom: 1em;
    right: 1em;
    translate: 0 -50%;
    line-height: 0;
}
#business .drawing_btn::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 70%;
    height: 70%;
    -webkit-mask-image: url(../img/business/btn.svg);
    mask-image: url(../img/business/btn.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #fff;
    z-index: 10;
    transition: left 0.5s;
}
#business .drawing_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 100%;
    height: 190%;
    background-color: #004ea2;
    border-radius: 50px;
    z-index: 5;
    transition: scale 0.5s, background-color 0.5s;
}
#business .drawing_btn:hover::after {
    scale: 1.15;
    background-color: #003771;
}
#business .drawing_morebtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#business .drawing_morebtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#business .drawing_morebtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#business .drawing_morebtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#business .drawing_morebtn:hover {
    background-color: #004ea2;
}
#business .drawing_morebtn:hover span {
    color: #fff;
}
#business .drawing_morebtn:hover::before {
    right: 0.85em;
}
#business .drawing_morebtn:hover::after {
    scale: 1;
}
#business .drawing_morebtn {
    margin: 0 auto;
}

/*==================================================================================================
	作業の様子
==================================================================================================*/
#atwork .flow {
    padding: 0 0;
}
#atwork .flow_secttl {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 min(5%, 50px);
}
#atwork .flow_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#atwork .flow_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #atwork .flow_secttl .ja {
        font-size: 4.5vw;
    }
}
#atwork .flow_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#atwork .flow_secttl .en.-active {
    opacity: 1;
}
#atwork .flow_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #atwork .flow_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#atwork .flow_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#atwork .flow_list {
    margin: 0px 0;
    position: relative;
}
#atwork .flow_item {
    width: 50vw;
    transition: -webkit-transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
    padding: 0 3.5%;
    position: relative;
    transition: all 0.5s;
}
@media (max-width: 1280px) {
    #atwork .flow_item {
        width: 70vw;
        padding: 0 5%;
    }
}
@media (max-width: 540px) {
    #atwork .flow_item {
        width: 80vw;
        padding: 0 7.5%;
    }
}
#atwork .flow_item:not(.swiper-slide-active) {
    opacity: 0.35;
}
@media (max-width: 840px) {
    #atwork .flow_item:not(.swiper-slide-active) {
        opacity: 0.25;
    }
}
#atwork .flow_img {
    position: relative;
}
#atwork .flow_img img {
    -o-object-fit: cover;
    object-fit: cover;
    aspect-ratio: 16/9;
    -o-object-position: center;
    object-position: center;
    border-radius: min(2.5vw, 10px);
}
#atwork .flow_num {
    position: absolute;
    bottom: 0.25em;
    left: 0.25em;
    background-color: #004ea2;
    color: #fff;
    font-size: clamp(4rem, 5.2vw, 7.2rem);
    line-height: 1;
    padding: 0.15em 0.25em;
    border-radius: min(2.5vw, 7.5px);
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
}
#atwork .flow_ttl {
    line-height: 1.35;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    font-weight: 700;
    color: #004ea2;
    margin-top: 1em;
    margin-bottom: 0.5em;
    position: relative;
    padding-left: 0.75em;
}
#atwork .flow_ttl::before {
    content: "";
    position: absolute;
    top: 55%;
    left: 0;
    translate: 0 -50%;
    width: 0.2em;
    height: 70%;
    background-color: #004ea2;
}
#atwork .flow .swiper-button-prev,
#atwork .flow .swiper-button-next {
    right: auto;
    translate: -50% -50%;
    width: min(10%, 50px);
    height: min(10%, 50px);
    transition: scale 0.5s;
    top: 40%;
    width: 60px;
    height: 60px;
}
@media (max-width: 1600px) {
    #atwork .flow .swiper-button-prev,
    #atwork .flow .swiper-button-next {
        top: 30%;
    }
}
@media (max-width: 840px) {
    #atwork .flow .swiper-button-prev,
    #atwork .flow .swiper-button-next {
        width: 45px;
        height: 45px;
    }
}
#atwork .flow .swiper-button-prev::before,
#atwork .flow .swiper-button-next::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 50%;
    height: 50%;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #fff;
    z-index: 10;
    transition: left 0.5s;
}
#atwork .flow .swiper-button-prev::after,
#atwork .flow .swiper-button-next::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 100%;
    height: 100%;
    background-color: #004ea2;
    border-radius: 50px;
    z-index: 5;
    transition: scale 0.5s, background-color 0.5s;
}
#atwork .flow .swiper-button-prev:hover::after,
#atwork .flow .swiper-button-next:hover::after {
    scale: 1.25;
    background-color: #003771;
}
#atwork .flow .swiper-button-prev {
    left: 28%;
}
@media (max-width: 1280px) {
    #atwork .flow .swiper-button-prev {
        left: 20%;
    }
}
@media (max-width: 840px) {
    #atwork .flow .swiper-button-prev {
        left: 10%;
    }
}
#atwork .flow .swiper-button-prev::before {
    rotate: 180deg;
}
#atwork .flow .swiper-button-prev:hover::before {
    left: 30%;
}
#atwork .flow .swiper-button-next {
    left: 72%;
}
@media (max-width: 1280px) {
    #atwork .flow .swiper-button-next {
        left: 80%;
    }
}
@media (max-width: 840px) {
    #atwork .flow .swiper-button-next {
        left: 90%;
    }
}
#atwork .flow .swiper-button-next:hover::before {
    left: 70%;
}
#atwork .gallery {
    padding: 0 0;
    margin-top: 0;
}
#atwork .gallery_img {
    position: absolute;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: min(10px, 2.5vw);
}
#atwork .gallery.-top {
    margin-bottom: 0;
}
#atwork .gallery.-top .gallery_inner {
    aspect-ratio: 3/1;
}
@media (max-width: 840px) {
    #atwork .gallery.-top .gallery_inner {
        aspect-ratio: 2.5/1;
    }
}
#atwork .gallery.-top .gallery_img:nth-child(1) {
    left: 0;
    bottom: 0;
    width: 50%;
    height: 80%;
    border-radius: 0 min(10px, 2.5vw) min(10px, 2.5vw) 0;
    background-image: url(../img/atwork/gallery_01.jpg);
}
@media (max-width: 840px) {
    #atwork .gallery.-top .gallery_img:nth-child(1) {
        width: 52.5%;
    }
}
#atwork .gallery.-top .gallery_img:nth-child(2) {
    right: 10%;
    top: 0;
    width: 30%;
    height: 60%;
    background-image: url(../img/atwork/gallery_02.jpg);
}
@media (max-width: 840px) {
    #atwork .gallery.-top .gallery_img:nth-child(2) {
        width: 47.5%;
        height: 70%;
        right: 5%;
    }
}
#atwork .gallery.-bottom {
    margin-top: clamp(50px, 8vw, 80px);
}
#atwork .gallery.-bottom .gallery_inner {
    aspect-ratio: 4/2.5;
}
@media (max-width: 840px) {
    #atwork .gallery.-bottom .gallery_inner {
        aspect-ratio: 4/3;
    }
}
#atwork .gallery.-bottom .gallery_img:nth-child(1) {
    left: 20%;
    top: 10%;
    width: 35%;
    height: 35%;
    background-image: url(../img/atwork/gallery_03.jpg);
    z-index: 10;
}
@media (max-width: 840px) {
    #atwork .gallery.-bottom .gallery_img:nth-child(1) {
        left: 15%;
        width: 42.5%;
        height: 37.5%;
    }
}
#atwork .gallery.-bottom .gallery_img:nth-child(2) {
    right: 0;
    top: 0;
    width: 35%;
    height: 75%;
    border-radius: min(10px, 2.5vw) 0 0 min(10px, 2.5vw);
    background-image: url(../img/atwork/gallery_04.jpg);
}
@media (max-width: 840px) {
    #atwork .gallery.-bottom .gallery_img:nth-child(2) {
        width: 50%;
        height: 85%;
    }
}
#atwork .gallery.-bottom .gallery_img:nth-child(3) {
    left: 10%;
    bottom: 0;
    width: 30%;
    height: 42.5%;
    background-image: url(../img/atwork/gallery_05.jpg);
}
@media (max-width: 840px) {
    #atwork .gallery.-bottom .gallery_img:nth-child(3) {
        width: 35%;
        left: 5%;
    }
}

/*==================================================================================================
	採用情報
==================================================================================================*/
#recruit .joblist {
    margin-bottom: 0;
}
#recruit .joblist_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#recruit .joblist_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #recruit .joblist_secttl .ja {
        font-size: 4.5vw;
    }
}
#recruit .joblist_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#recruit .joblist_secttl .en.-active {
    opacity: 1;
}
#recruit .joblist_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #recruit .joblist_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#recruit .joblist_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#recruit .joblist_txt {
    font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 0.85);
    font-weight: 700;
}
#recruit .joblist_morebtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#recruit .joblist_morebtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#recruit .joblist_morebtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#recruit .joblist_morebtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#recruit .joblist_morebtn:hover {
    background-color: #004ea2;
}
#recruit .joblist_morebtn:hover span {
    color: #fff;
}
#recruit .joblist_morebtn:hover::before {
    right: 0.85em;
}
#recruit .joblist_morebtn:hover::after {
    scale: 1;
}
#recruit .joblist_morebtn {
    margin-top: 2em;
}
#recruit .joboffer_content {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: clamp(50px, 8vw, 80px);
}
#recruit .joboffer_tab {
    width: 30%;
}
@media (max-width: 1024px) {
    #recruit .joboffer_tab {
        width: 100%;
    }
}
#recruit .joboffer_tab .tab_list {
    display: inline-flex;
    flex-direction: column;
    gap: 0.35em 2.5%;
    position: sticky;
    top: 150px;
    min-height: 200px;
}
@media (max-width: 1024px) {
    #recruit .joboffer_tab .tab_list {
        min-height: auto;
        height: auto;
        top: 0;
        width: 100%;
        display: flex;
        flex-wrap: wrap;
    }
}
#recruit .joboffer_tab .tab_item {
    position: relative;
    background-color: #aaa;
    border-radius: min(2.5px, 2.5vw);
    transition: 0.5s background-color;
}
#recruit .joboffer_tab .tab_item::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    translate: 0 -50%;
    height: 105%;
    width: 30%;
    background: #f2f2f2;
    background: linear-gradient(90deg, rgba(242, 242, 242, 0) 0%, #f2f2f2 100%);
}
@media (max-width: 1024px) {
    #recruit .joboffer_tab .tab_item {
        width: 47.5%;
    }
}
@media (max-width: 840px) {
    #recruit .joboffer_tab .tab_item {
        width: 70%;
    }
}
#recruit .joboffer_tab .tab_item span {
    font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 0.75);
    font-weight: 700;
    line-height: 1.35;
    position: relative;
    cursor: pointer;
    padding: 1em 1.5em 1em 2.5em;
    display: inline-block;
    transition: 0.5s color;
    word-break: auto-phrase;
    color: #fff;
}
#recruit .joboffer_tab .tab_item span::before, #recruit .joboffer_tab .tab_item span::after {
    content: "";
    position: absolute;
    display: block;
    height: 1.25em;
    width: 1.25em;
    left: 0.5em;
    top: 50%;
    border-radius: 50%;
    translate: 0 -50%;
    scale: 0.65;
    background: #fff;
    transition: 0.35s scale, 0.5s opacity;
}
#recruit .joboffer_tab .tab_item span::before {
    background: #004ea2;
    scale: 0;
    opacity: 0;
    transition: 0.35s scale, 0.5s opacity;
    z-index: 5;
}
#recruit .joboffer_tab .tab_item.-active {
    background-color: #004ea2;
}
#recruit .joboffer_tab .tab_item.-active span {
    color: #fff;
}
#recruit .joboffer_tab .tab_item.-active span::before {
    background: #004ea2;
    scale: 0.25;
    opacity: 1;
}
#recruit .joboffer_tab .tab_item.-active span::after {
    scale: 0.65;
    opacity: 1;
}
#recruit .joboffer_tab .tab_item:hover {
    background-color: #004ea2;
}
#recruit .joboffer_tab .tab_item:hover span::before {
    background: #004ea2;
    scale: 0.25;
    opacity: 1;
}
#recruit .joboffer_desc {
    width: 65%;
}
@media (max-width: 1024px) {
    #recruit .joboffer_desc {
        width: 100%;
        margin-top: clamp(50px, 8vw, 80px);
    }
}
#recruit .joboffer_desc .desc_inner {
    display: none;
    position: relative;
}
#recruit .joboffer_desc .desc_inner.-active {
    display: block;
}
#recruit .joboffer_desc .desc_ttl {
    display: block;
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    font-weight: 700;
    line-height: 1.35;
    margin-bottom: 0.75em;
    color: #004ea2;
}
#recruit .joboffer_desc .desc_list {
    display: flex;
    flex-direction: column;
}
#recruit .joboffer_desc .desc_item {
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #004ea2;
    padding: 2em 0;
}
#recruit .joboffer_desc .desc_item:first-child {
    border-top: 1px solid #004ea2;
}
@media (max-width: 840px) {
    #recruit .joboffer_desc .desc_item {
        padding: 1em 0;
    }
}
#recruit .joboffer_desc .desc_item .ttl {
    font-weight: 700;
    width: 120px;
    color: #004ea2;
}
@media (max-width: 540px) {
    #recruit .joboffer_desc .desc_item .ttl {
        width: 100%;
    }
}
#recruit .joboffer_desc .desc_item .txt {
    width: calc(100% - 120px);
    padding-left: 1em;
}
@media (max-width: 540px) {
    #recruit .joboffer_desc .desc_item .txt {
        width: 100%;
        padding-left: 0;
    }
}
#recruit .joboffer_desc .desc_morebtn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#recruit .joboffer_desc .desc_morebtn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#recruit .joboffer_desc .desc_morebtn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#recruit .joboffer_desc .desc_morebtn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#recruit .joboffer_desc .desc_morebtn:hover {
    background-color: #004ea2;
}
#recruit .joboffer_desc .desc_morebtn:hover span {
    color: #fff;
}
#recruit .joboffer_desc .desc_morebtn:hover::before {
    right: 0.85em;
}
#recruit .joboffer_desc .desc_morebtn:hover::after {
    scale: 1;
}
#recruit .joboffer_desc .desc_morebtn {
    margin-top: 2em;
}

/*==================================================================================================
	会社概要
==================================================================================================*/
#company .values_inner {
    z-index: 10;
}
#company .values_content {
    max-width: 1280px;
    margin: 0 auto;
}
#company .values_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#company .values_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #company .values_secttl .ja {
        font-size: 4.5vw;
    }
}
#company .values_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#company .values_secttl .en.-active {
    opacity: 1;
}
#company .values_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #company .values_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#company .values_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#company .values_copy {
    display: flex;
    flex-direction: column;
    gap: 0.5em 0;
    font-size: calc(clamp(4rem, 5.2vw, 7.2rem) * 0.75);
}
@media (max-width: 540px) {
    #company .values_copy {
        font-size: 6vw;
    }
}
#company .values_copy .txt {
    line-height: 1.35;
    letter-spacing: 0.015em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#company .values_copy .txt.-active {
    opacity: 1;
}
#company .values_copy .txt.-active span {
    translate: 0 0;
}
#company .values_copy .txt span {
    line-height: inherit;
    display: inline-block;
    translate: 0 1em;
    transition: translate 1s;
}
@media (max-width: 540px) {
    #company .values_copy.-pc {
        display: none;
    }
}
@media (min-width: 541px) {
    #company .values_copy.-sp {
        display: none;
    }
}
#company .values_img {
    margin-top: clamp(50px, 8vw, 80px);
    aspect-ratio: 2/1;
    position: relative;
}
@media (max-width: 840px) {
    #company .values_img {
        aspect-ratio: 1/1.5;
    }
}
#company .values_img .img {
    position: absolute;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: min(10px, 2.5vw);
    z-index: 10;
}
#company .values_img .img:nth-child(1) {
    bottom: 0;
    left: 3.5%;
    width: 45%;
    height: 65%;
    background-image: url(../img/company/values_01.jpg);
}
@media (max-width: 840px) {
    #company .values_img .img:nth-child(1) {
        bottom: auto;
        top: 5%;
        width: 80%;
        height: 40%;
    }
}
#company .values_img .img:nth-child(2) {
    top: 0;
    right: 0;
    width: 35%;
    height: 50%;
    background-image: url(../img/company/values_02.jpg);
}
@media (max-width: 840px) {
    #company .values_img .img:nth-child(2) {
        top: 50%;
        width: 65%;
        height: 30%;
    }
}
#company .values_img .img:nth-child(3) {
    top: 40%;
    right: 25%;
    width: 20%;
    height: 40%;
    background-image: url(../img/company/values_03.jpg);
}
@media (max-width: 840px) {
    #company .values_img .img:nth-child(3) {
        top: 75%;
        right: 45%;
        width: 40%;
        height: 25%;
    }
}
#company .values_deco.-deco_01 {
    position: absolute;
    width: min(0.75vw, 5px);
    height: 130%;
    rotate: 45deg;
    top: 10vw;
    right: -5%;
    translate: -50% 0;
    -webkit-transform-origin: left top;
    transform-origin: left top;
}
@media (max-width: 840px) {
    #company .values_deco.-deco_01 {
        top: 90vw;
        right: -10%;
        height: 60%;
    }
}
#company .values_deco.-deco_01::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #004ea2;
    transition: 2s height;
}
#company .values_deco.-deco_01.-active::before {
    height: 100%;
}
#company .values_deco.-deco_02 {
    position: absolute;
    left: -15%;
    top: 40%;
    translate: 0 -50%;
    width: 45%;
    mix-blend-mode: color-dodge;
    -webkit-animation: pulse 5s ease-in-out infinite;
    animation: pulse 5s ease-in-out infinite;
}
@media (max-width: 840px) {
    #company .values_deco.-deco_02 {
        left: auto;
        right: -15%;
        top: 30%;
        width: 75%;
    }
}
@keyframes pulse {
    0%, 100% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
    50% {
        -webkit-transform: scale(1.25);
        transform: scale(1.25);
    }
}
#company .message {
    margin-bottom: 0;
    z-index: 10;
}
#company .message_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#company .message_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #company .message_secttl .ja {
        font-size: 4.5vw;
    }
}
#company .message_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#company .message_secttl .en.-active {
    opacity: 1;
}
#company .message_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #company .message_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#company .message_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#company .message_content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#company .message_img {
    width: 40%;
}
@media (max-width: 840px) {
    #company .message_img {
        width: 80%;
        margin-top: 0;
    }
}
#company .message_img img {
    border-radius: min(2.5vw, 10px);
}
#company .message_unit {
    width: 55%;
}
@media (max-width: 840px) {
    #company .message_unit {
        width: 90%;
        margin-left: auto;
        margin-top: clamp(50px, 8vw, 80px);
    }
}
#company .message_txt {
    font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 0.85);
}
@media (max-width: 540px) {
    #company .message_txt {
        font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 0.75);
    }
}
#company .message_name {
    font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 0.85);
    color: #004ea2;
    margin-top: 1.5em;
    font-weight: 700;
}
#company .message_name .sub {
    font-weight: inherit;
}
#company .message_name .main {
    display: flex;
    gap: 0 0.25em;
    align-items: baseline;
    font-weight: inherit;
}
#company .message_name .main .name {
    font-size: calc(clamp(2rem, 2.4vw, 2.4rem) * 1.25);
    font-weight: inherit;
    line-height: 1.35;
}
#company .profile {
    background-image: url(../img/top/works_bg.jpg);
    background-size: 50px;
    background-position: center;
    background-repeat: repeat;
    padding: clamp(80px, 12vw, 200px) 5%;
    margin: calc(clamp(80px, 12vw, 200px) * 0.25) auto;
}
@media (max-width: 840px) {
    #company .profile {
        padding: calc(clamp(80px, 12vw, 200px) * 1.75) 5% calc(clamp(80px, 12vw, 200px) * 0.75);
    }
}
#company .profile::before, #company .profile::after {
    left: 50%;
    translate: -50% 0;
    width: 150%;
    height: 50%;
    background: #fff;
    -webkit-filter: blur(20px);
    filter: blur(20px);
}
#company .profile::before {
    content: "";
    position: absolute;
    top: -50px;
    background: linear-gradient(0deg, rgba(242, 242, 242, 0) 0%, #f2f2f2 80%, #f2f2f2 100%);
}
#company .profile::after {
    content: "";
    position: absolute;
    bottom: -50px;
    background: linear-gradient(180deg, rgba(242, 242, 242, 0) 0%, #f2f2f2 80%, #f2f2f2 100%);
}
#company .profile_inner {
    z-index: 10;
}
#company .profile_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #fff;
}
#company .profile_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #fff;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #company .profile_secttl .ja {
        font-size: 4.5vw;
    }
}
#company .profile_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#company .profile_secttl .en.-active {
    opacity: 1;
}
#company .profile_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #company .profile_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#company .profile_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #fff;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#company .profile_list {
    display: flex;
    flex-direction: column;
    background-color: #f2f2f2;
    padding: clamp(50px, 8vw, 80px) min(5%, 50px);
    border-radius: min(2.5vw, 2.5px);
}
#company .profile_item {
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #004ea2;
    padding: 2em 0;
}
#company .profile_item:first-child {
    border-top: 1px solid #004ea2;
}
@media (max-width: 840px) {
    #company .profile_item {
        padding: 1em 0;
    }
}
#company .profile_item .ttl {
    font-weight: 700;
    width: 120px;
    color: #004ea2;
}
@media (max-width: 540px) {
    #company .profile_item .ttl {
        width: 100%;
    }
}
#company .profile_item .txt {
    width: calc(100% - 120px);
    padding-left: 1em;
}
@media (max-width: 540px) {
    #company .profile_item .txt {
        width: 100%;
        padding-left: 0;
    }
}
#company .profile_map {
    margin-top: calc(clamp(50px, 8vw, 80px) * 0.5);
}
#company .profile_map iframe {
    width: 100%;
    height: 400px;
    border-radius: min(2.5vw, 2.5px);
}
@media (max-width: 840px) {
    #company .profile_map iframe {
        height: 300px;
    }
}
#company .history {
    margin-top: 0;
}
#company .history_secttl .ja {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    position: relative;
    padding-left: 0.65em;
    font-weight: 700;
    transition: color 0.5s;
    line-height: 1.15;
    color: #333;
}
#company .history_secttl .ja::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
@media (max-width: 540px) {
    #company .history_secttl .ja {
        font-size: 4.5vw;
    }
}
#company .history_secttl .en {
    font-size: clamp(6rem, 8vw, 10rem);
    margin-top: 0.075em;
    margin-bottom: 0.75em;
    line-height: 1.15;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s;
}
#company .history_secttl .en.-active {
    opacity: 1;
}
#company .history_secttl .en.-active span {
    translate: 0 0;
}
@media (max-width: 540px) {
    #company .history_secttl .en {
        font-size: 10vw;
        margin-bottom: 0.5em;
    }
}
#company .history_secttl .en span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#company .history_list {
    display: flex;
    flex-direction: column;
}
#company .history_item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
#company .history_year {
    width: 140px;
    color: #004ea2;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    font-size: clamp(3.2rem, 4vw, 4.5rem);
    opacity: 0.25;
}
@media (max-width: 840px) {
    #company .history_year {
        width: 100px;
    }
}
#company .history_content {
    width: calc(95% - 140px);
    display: flex;
    flex-wrap: wrap;
    border-bottom: 1px solid #004ea2;
    padding: 2em 0;
    position: relative;
}
@media (max-width: 840px) {
    #company .history_content {
        width: calc(95% - 100px);
    }
}
#company .history_content::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -2em;
    translate: 0 -50%;
    border-radius: 50px;
    width: 1em;
    height: 1em;
    background-color: #fff;
    border: 1px solid #004ea2;
    z-index: 5;
}
#company .history_content::after {
    content: "";
    position: absolute;
    top: 50%;
    left: -1.5em;
    translate: 0 -50%;
    border-radius: 50px;
    width: 1px;
    height: 101%;
    background-color: #004ea2;
}
#company .history_content .month {
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    width: 80px;
    color: #004ea2;
}
@media (max-width: 540px) {
    #company .history_content .month {
        width: 100%;
    }
}
#company .history_content .txt {
    width: calc(100% - 120px);
    padding-left: 1em;
}
@media (max-width: 540px) {
    #company .history_content .txt {
        width: 100%;
        padding-left: 0;
    }
}

/*==================================================================================================
	お問い合わせ
==================================================================================================*/
#contact .tel {
    margin-bottom: 0;
}
#contact .tel_inner {
    border-radius: min(2.5vw, 20px);
    border: min(0.75vw, 3px) solid #004ea2;
}
#contact .tel_ttl {
    font-size: clamp(2.4rem, 3.2vw, 3.2rem);
    font-weight: 700;
    line-height: 1.35;
    text-align: center;
    background-color: #004ea2;
    color: #fff;
    padding: 0.5em min(5%, 50px);
    border-radius: min(1.65vw, 15px) min(1.65vw, 15px) 0 0;
}
#contact .tel_info {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
    padding: calc(clamp(50px, 8vw, 80px) * 0.35) min(5%, 50px);
}
#contact .tel_num {
    display: flex;
    align-items: baseline;
    gap: 0 0.25em;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    line-height: 1.35;
    color: #004ea2;
}
#contact .tel_num .en {
    font-family: inherit;
    font-weight: inherit;
    line-height: inherit;
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    color: inherit;
}
#contact .tel_num .num {
    font-family: inherit;
    font-weight: inherit;
    line-height: inherit;
    font-size: calc(clamp(4rem, 5.2vw, 7.2rem) * 0.85);
    color: inherit;
}
@media (max-width: 840px) {
    #contact .tel_num .num {
        font-size: calc(clamp(4rem, 5.2vw, 7.2rem) * 1.25);
    }
}
@media (max-width: 540px) {
    #contact .tel_num .num {
        font-size: 8vw;
    }
}
#contact .tel_num:hover {
    opacity: 0.8;
}
#contact .tel_time {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.1em 0.5em;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.35;
}
@media (max-width: 840px) {
    #contact .tel_time {
        flex-direction: row;
        font-size: 1.6rem;
    }
}
#contact .tel_time span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
}
#contact .tel_time .time .num {
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    font-size: clamp(2rem, 2.4vw, 2.4rem);
}
#contact .form {
    margin-top: clamp(50px, 8vw, 80px);
}
#contact .form_txt {
    text-align: center;
    margin-bottom: 2em;
}
#contact .form_list {
    display: flex;
    flex-direction: column;
    gap: 1.5em 0;
}
#contact .form_item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
#contact .form_item.-align {
    align-items: flex-start;
}
#contact .form_item.-align .label {
    margin-top: 0.5em;
}
@media (max-width: 840px) {
    #contact .form_item.-align .label {
        margin-top: 0;
    }
}
#contact .form_item .label {
    display: block;
    width: 230px;
    font-weight: 700;
}
@media (max-width: 840px) {
    #contact .form_item .label {
        width: 100%;
        margin-bottom: 0.35em;
    }
}
#contact .form_item .label.-required::after {
    content: "必須";
    font-size: 1.2rem;
    background-color: #004ea2;
    color: #fff;
    padding: 0.1em 0.5em 0.25em;
    translate: 0 -0.1em;
    line-height: 1.15;
    display: inline-block;
    margin-left: 10px;
}
#contact .form_item .label + * {
    width: calc(100% - 230px - 1em);
    margin-left: 1em;
    height: 3em;
}
@media (max-width: 840px) {
    #contact .form_item .label + * {
        width: 100%;
        margin-left: 0;
    }
}
#contact .form_item .input {
    padding: 0.5em;
    background-color: #e3e7e8;
    border: none;
    outline: none;
}
#contact .form_item .input.-short {
    width: 300px;
}
@media (max-width: 540px) {
    #contact .form_item .input.-short {
        width: 100%;
    }
}
#contact .form_item .textarea {
    resize: vertical;
    padding: 0.5em;
    background-color: #e3e7e8;
    border: none;
    outline: none;
    height: auto;
}
#contact .form_item .radio {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    min-height: 3em;
    height: auto;
}
@media (max-width: 840px) {
    #contact .form_item .radio {
        min-height: 2.5em;
    }
}
#contact .form_item .radio_list {
    display: flex;
    flex-wrap: wrap;
}
#contact .form_item .radio_item {
    position: relative;
    display: flex;
}
#contact .form_item .radio_item:not(:last-child) {
    margin-right: 1.25em;
}
#contact .form_item .radio_item input[type=radio] {
    width: 0;
    visibility: hidden;
}
#contact .form_item .radio_item input[type=radio]:checked + label::after {
    scale: 0.65;
    opacity: 1;
}
#contact .form_item .radio_item label {
    position: relative;
    cursor: pointer;
    padding-left: 1.5em;
}
#contact .form_item .radio_item label::before, #contact .form_item .radio_item label::after {
    content: "";
    position: absolute;
    display: block;
    height: 1em;
    width: 1em;
    left: 0;
    top: 50%;
    border-radius: 50%;
    translate: 0 -47.5%;
}
#contact .form_item .radio_item label::before {
    background-color: #fff;
    border: 1px solid #004ea2;
}
#contact .form_item .radio_item label::after {
    background: #004ea2;
    border: 1px solid #004ea2;
    scale: 0;
    opacity: 0;
    transition: 0.35s scale, 0.5s opacity;
}
#contact .form_item .radio_txt {
    font-size: 0.85em;
    width: 100%;
    margin-top: 0.5em;
}
#contact .form_item .address {
    min-height: 3em;
    height: auto;
}
#contact .form_item .address .num {
    display: flex;
    align-items: center;
    gap: 0 0.5em;
    margin-bottom: 10px;
}
#contact .form_item .address .num input {
    padding: 0.5em;
    background-color: #ebf2ef;
    border: none;
    outline: none;
    width: 200px;
}
#contact .form_item .address .textarea {
    resize: vertical;
    padding: 0.5em;
    background-color: #ebf2ef;
    border: none;
    outline: none;
    height: auto;
    border-radius: 2px;
    width: 100%;
    margin-bottom: -5px;
}
#contact .form_agree {
    margin-top: 50px;
}
#contact .form_agree .agree_txt {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
}
#contact .form_agree .agree_link {
    text-decoration: underline;
    color: #004ea2;
    display: inline-block;
}
#contact .form_agree .agree_link:hover {
    opacity: 0.7;
}
#contact .form_agree .agree_check {
    margin-top: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
}
#contact .form_agree .agree_check input[type=checkbox] {
    width: 0;
    visibility: hidden;
}
#contact .form_agree .agree_check input[type=checkbox]:checked + label::before {
    border-color: #004ea2;
}
#contact .form_agree .agree_check input[type=checkbox]:checked + label::after {
    opacity: 1;
    scale: 1;
}
#contact .form_agree .agree_check label {
    position: relative;
    cursor: pointer;
    padding: 0 1em 0 2em;
}
#contact .form_agree .agree_check label::before {
    background: #fff;
    border: 1px solid #004ea2;
    content: "";
    display: block;
    height: 1em;
    width: 1em;
    left: 0;
    position: absolute;
    top: 50%;
    translate: 0 -45%;
}
#contact .form_agree .agree_check label::after {
    border-right: 3px solid #004ea2;
    border-bottom: 3px solid #004ea2;
    content: "";
    display: block;
    height: 1em;
    width: 0.5em;
    position: absolute;
    top: 50%;
    left: 2.5%;
    translate: 0 -75%;
    opacity: 0;
    rotate: 45deg;
    scale: 0.7;
    opacity: 0;
    transition: 0.35s scale, 0.5s opacity;
}
#contact .form_btn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid transparent;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
    margin: 2em auto 0;
    display: block;
    background-color: #ddd;
}
#contact .form_btn span {
    font-weight: inherit;
    line-height: inherit;
    color: #888;
    transition: color 0.5s;
}
#contact .form_btn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s, opacity 0.5s;
    opacity: 0;
}
#contact .form_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s, opacity 0.5s;
    opacity: 0;
}
#contact .form_btn.-active {
    border: 1px solid #004ea2;
    background-color: transparent;
}
#contact .form_btn.-active span {
    color: #004ea2;
}
#contact .form_btn.-active::before {
    opacity: 1;
}
#contact .form_btn.-active:hover {
    background-color: #004ea2;
}
#contact .form_btn.-active:hover span {
    color: #fff;
}
#contact .form_btn.-active:hover::before {
    right: 0.85em;
}
#contact .form_btn.-active:hover::after {
    opacity: 1;
    scale: 1;
}
#contact .form input[type=radio],
#contact .form input[type=checkbox] {
    accent-color: #000;
}

.confirm_custom {
    margin-top: 0;
    padding-top: 250px;
}
@media (max-width: 1280px) {
    .confirm_custom {
        padding-top: clamp(140px, 18vw, 200px);
    }
}
.confirm_custom_ttl {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    text-align: center;
    color: #004ea2;
    display: block;
    margin-bottom: 0.75em;
}
.confirm_custom_txt {
    text-align: center;
    display: block;
}

.confirm-items {
    width: 100%;
    margin-top: 30px;
}
.confirm-items tbody {
    width: 100%;
    border-top: 1px solid #004ea2;
}
.confirm-items tbody tr {
    display: flex;
    flex-wrap: wrap;
}
.confirm-items tbody tr th {
    display: block;
    width: 230px;
    text-align: left;
    font-weight: normal;
    border-bottom: 1px solid #004ea2;
    padding: 1.5em 0;
    font-weight: 700;
}
@media screen and (max-width: 840px) {
    .confirm-items tbody tr th {
        width: 100%;
        border-bottom: none;
        padding: 1em 0 1.5px;
    }
}
.confirm-items tbody tr td {
    display: block;
    width: calc(100% - 230px);
    text-align: left;
    border-bottom: 1px solid #004ea2;
    padding: 1.5em 0 1.5em 1em;
}
@media screen and (max-width: 840px) {
    .confirm-items tbody tr td {
        width: 100%;
        padding-left: 0px;
        padding: 1.5px 0 1em;
    }
}

.error-items .error-item {
    border-radius: 5px;
    padding: 1em;
    display: flex;
    flex-wrap: wrap;
    background-color: #fff;
}
.error-items .error-item:not(:last-child) {
    margin-bottom: 5px;
}
.error-items .error-item-label {
    display: block;
    width: 150px;
}
@media screen and (max-width: 840px) {
    .error-items .error-item-label {
        width: 100%;
    }
}
.error-items .error-item-body {
    display: block;
    width: calc(100% - 150px);
    padding-left: 1em;
    word-break: break-all;
    color: #c40000;
}
@media screen and (max-width: 840px) {
    .error-items .error-item-body {
        width: 100%;
        padding-left: 0px;
    }
}

.confirm-btns {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}
.confirm-btns .confirm-btn.confirm-btn-submit {
    border: none;
    padding: 0.75em 1.5em;
    width: 220px;
    max-width: 100%;
    margin: 2em auto 20px;
    background-color: #004ea2;
    font-size: 2rem;
    color: #fff;
    border-radius: 50px;
}
.confirm-btns .confirm-btn.confirm-btn-submit:hover {
    opacity: 0.7;
}
.confirm-btns .confirm-btn.confirm-btn-back {
    font-size: 1.6rem;
    width: 180px;
    max-width: 100%;
    margin: 10px auto 0px;
    background-color: #aaa;
    color: #fff;
    border: none;
    padding: 0.75em 1.5em;
    transition: 0.5s opacity;
    border-radius: 50px;
}
.confirm-btns .confirm-btn.confirm-btn-back:hover {
    opacity: 0.7;
}

.error_messe {
    margin-top: 30px;
    text-align: center;
}

/*==================================================================================================
	プライバシーポリシー
==================================================================================================*/
@media (max-width: 840px) {
    #privacypolicy .cmn_pagehead_ttl .en {
        font-size: 10vw;
    }
}
#privacypolicy .sec_head .txt {
    margin-bottom: 2em;
}
#privacypolicy .sec_list {
    display: flex;
    flex-direction: column;
    gap: 2em 0;
}
#privacypolicy .sec_item .ttl {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    color: #004ea2;
    margin-bottom: 0.25em;
    padding-left: 0.75em;
    position: relative;
}
#privacypolicy .sec_item .ttl::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    translate: 0 -50%;
    width: 0.25em;
    height: 0.25em;
    background-color: #004ea2;
    border-radius: 50px;
}
/*==================================================================================================
	404,サンクスページ
==================================================================================================*/
#error .sec,
#thanks .sec {
    margin-top: 0;
    padding-top: 250px;
}
@media (max-width: 1280px) {
    #error .sec,
    #thanks .sec {
        padding-top: clamp(140px, 18vw, 200px);
    }
}
#error .sec_ttl,
#thanks .sec_ttl {
    font-size: clamp(4rem, 5.2vw, 7.2rem);
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    letter-spacing: 0.025em;
    overflow: hidden;
    line-height: 1.15;
    opacity: 0;
    transition: opacity 0.5s;
    display: flex;
    justify-content: center;
}
@media (max-width: 540px) {
    #error .sec_ttl,
    #thanks .sec_ttl {
        font-size: 8.5vw;
    }
}
#error .sec_ttl.-active,
#thanks .sec_ttl.-active {
    opacity: 1;
}
#error .sec_ttl.-active span,
#thanks .sec_ttl.-active span {
    translate: 0 0;
}
#error .sec_ttl span,
#thanks .sec_ttl span {
    line-height: inherit;
    font-family: inherit;
    font-weight: inherit;
    color: #004ea2;
    translate: 0 1em;
    display: inline-block;
    transition: translate 1s;
}
#error .sec_txt,
#thanks .sec_txt {
    text-align: center;
    margin: 1.5em 0 2.5em;
}
#error .sec_btn,
#thanks .sec_btn {
    font-size: clamp(2rem, 2.4vw, 2.4rem);
    font-weight: 700;
    line-height: 1.35;
    border: 1px solid #004ea2;
    border-radius: 50px;
    padding: 0.5em 3.25em 0.65em 1em;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    position: relative;
}
#error .sec_btn span,
#thanks .sec_btn span {
    font-weight: inherit;
    line-height: inherit;
    color: #004ea2;
    transition: color 0.5s;
}
#error .sec_btn::before,
#thanks .sec_btn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 1.5em;
    translate: 0 -50%;
    width: 1em;
    height: 1em;
    -webkit-mask-image: url(../img/cmn/arrow.svg);
    mask-image: url(../img/cmn/arrow.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    background-color: #004ea2;
    z-index: 10;
    transition: right 0.5s, background-color 0.5s;
}
#error .sec_btn::after,
#thanks .sec_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.5em;
    translate: 0 -50%;
    width: 1.75em;
    height: 1.75em;
    background-color: #fff;
    border-radius: 50px;
    z-index: 5;
    scale: 0;
    transition: scale 0.5s;
}
#error .sec_btn:hover,
#thanks .sec_btn:hover {
    background-color: #004ea2;
}
#error .sec_btn:hover span,
#thanks .sec_btn:hover span {
    color: #fff;
}
#error .sec_btn:hover::before,
#thanks .sec_btn:hover::before {
    right: 0.85em;
}
#error .sec_btn:hover::after,
#thanks .sec_btn:hover::after {
    scale: 1;
}
#error .sec_btn,
#thanks .sec_btn {
    margin: 0 auto;
}