@charset "UTF-8";

/* header
-------------------*/

.header {
    display: flex;
    justify-content: space-between;
    padding: 0 50px;
    width: 100%;
    height: 177px;
    background-color: #fff;
    position: relative;
    z-index: 1;
}

.header-top {
    height: 253px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, 0.8) 65%, rgba(255, 255, 255, 0)) 100%;
    position: absolute;
    top: 0;
}

.h-logo {
    margin-top: 54px;
}

.h-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    align-content: flex-start;
    justify-content: flex-end;
    gap: 35px 43px;
    width: 595px;
    margin-top: 34px;
}

.h-nav {
    width: 100%;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1;
}

.h-nav_list {
    display: flex;
    justify-content: space-between;
}


/* main-vis
-------------------*/
.vis {
    position: relative;
}

.main-vis {
    width: 100%;
    height: 1043px;
    position: relative;
    overflow: hidden;
}

.main-vis_img {
    position: absolute;
    top: 0;
    right: calc(50% - 960px);
}

@media screen and (min-width: 1920px) {
    .main-vis_img {
        right: 0;
    }
}

.main-vis_catch {
    position: absolute;
    top: 690px;
    left: calc(50% - 810px);
}

@media screen and (max-width: 1710px) {
    .main-vis_catch {
        left: 50px;
    }
}

.main-vis_catch::before {
    content: "";
    width: 273px;
    height: 342px;
    background: url(/images/key/deco.png) no-repeat center / contain;
    position: absolute;
    top: -170px;
    left: -195px;
    z-index: -1;
}

/* sub-vis
-------------------*/

.sub-vis {
    width: 100%;
    height: 500px;
    position: relative;
    overflow: hidden;
}

.sub-vis::after {
    content: "";
    width: 100vw;
    height: 423px;
    border-radius: 50px 0 0 50px;
    background: rgba(21, 103, 161, 0.23);
    position: absolute;
    left: calc(50% - 115px);
    top: 30px;
    z-index: -1;
}

.sub-vis_img {
    position: absolute;
    top: 0;
    right: calc(50% - 540px);
}

.sub-vis_img img {
    border-radius: 50px;
}

.sub-vis_title {
    position: absolute;
    top: 333px;
    left: calc(50% - 810px);
    z-index: 1;
}

@media screen and (max-width: 1710px) {
    .sub-vis_title {
        left: 50px;
    }
}

.sub-vis_title::before {
    content: "";
    width: 273px;
    height: 342px;
    background: url(/images/key/deco.png) no-repeat center / contain;
    position: absolute;
    top: -175px;
    left: -190px;
    z-index: -1;
}

.sub-vis_title .txt {
    display: inline-block;
    min-width: 500px;
    height: 90px;
    padding: 0 50px;
    border-radius: 10px 10px 0 0;
    background-color: #fff;
    border-bottom: 1px solid #1567a1;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: 90px;
    text-align: center;
}

.sub-vis_title .txt::first-letter {
    color: #1567a1;
}

/* top
-------------------*/

.top-btn {
    width: 65px;
    height: 65px;
    position: fixed;
    right: 70px;
    bottom: 50px;
    z-index: 5;
}

.worries {
    width: 1620px;
    margin-top: 230px;
    padding-bottom: 70px;
    border-radius: 50px;
    background-color: #e0eff4;
    position: relative;
    left: calc(50% - 810px);
    position: relative;
}

.worries::before {
    content: "";
    width: 237px;
    height: 196px;
    background: url(/images/top/illust_01.png) no-repeat bottom center / contain;
    position: absolute;
    top: -196px;
    right: 230px;
}

.worries_wrapper {
    position: relative;
}

.worries_title {
    width: 100%;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: calc(80 / 46);
    text-align: center;
    position: absolute;
    top: -220px;
    left: 50%;
    transform: translateX(-50%);
}

.worries_title .color {
    color: #1567a1;
}

.worries_img {
    padding-top: 30px;
    text-align: center;
}

.worries_item:nth-child(1) {
    position: absolute;
    top: 0;
    left: 0;
}

.worries_item:nth-child(2) {
    position: absolute;
    top: 0;
    right: 0;
}

.worries_item:nth-child(3) {
    position: absolute;
    top: 320px;
    left: 0;
}

.worries_item:nth-child(4) {
    position: absolute;
    top: 320px;
    right: 0;
}

.worries_item a {
    width: 320px;
    height: 243px;
    border: 4px solid #fff;
    border-radius: 30px;
    background-color: #fff;
    position: relative;
    overflow: hidden;
}

.worries_item_btn {
    display: flex;
    align-items: center;
    gap: 5px;
    font-family: "Zen Maru Gothic";
    font-size: 17px;
    font-weight: 600;
    line-height: 1;
    position: absolute;
    bottom: 15px;
    right: 15px;
}

.worries_item_btn::after {
    content: "";
    display: inline-block;
    width: 31px;
    height: 31px;
}

.worries_item:nth-child(1) .worries_item_btn {
    color: #d87990;
}

.worries_item:nth-child(2) .worries_item_btn {
    color: #3b8b34;
}

.worries_item:nth-child(3) .worries_item_btn {
    color: #d98d34;
}

.worries_item:nth-child(4) .worries_item_btn {
    color: #4397c3;
}

.worries_item:nth-child(1) .worries_item_btn::after {
    background: url(/images/top/worries_btn_01.png) no-repeat center / contain;
}

.worries_item:nth-child(2) .worries_item_btn::after {
    background: url(/images/top/worries_btn_02.png) no-repeat center / contain;
}

.worries_item:nth-child(3) .worries_item_btn::after {
    background: url(/images/top/worries_btn_03.png) no-repeat center / contain;
}

.worries_item:nth-child(4) .worries_item_btn::after {
    background: url(/images/top/worries_btn_04.png) no-repeat center / contain;
}

/* .worries_item a::before {
    content: "check！";
    position: absolute;

}

.worries_item a::after {
    content: "";
    width: 31px;
    height: 31px;
    position: absolute;
    right: 15px;
    bottom: 15px;
}

.worries_item:nth-child(1) a::after {
    background: url(/images/top/worries_btn_01.png) no-repeat center / contain;
}

.worries_item:nth-child(2) a::after {
    background: url(/images/top/worries_btn_02.png) no-repeat center / contain;
}

.worries_item:nth-child(3) a::after {
    background: url(/images/top/worries_btn_03.png) no-repeat center / contain;
}

.worries_item:nth-child(4) a::after {
    background: url(/images/top/worries_btn_04.png) no-repeat center / contain;
} */

.worries_item_title {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 320px;
    height: 100px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: calc(37 / 22);
    text-align: center;
}

.worries_item:nth-child(1) .worries_item_title {
    background-color: #f1dae0;
    color: #d87990;
    -webkit-text-stroke: 6px #fff;
    paint-order: stroke;
}

.worries_item:nth-child(2) .worries_item_title {
    background-color: #c9e5c6;
    color: #3b8b34;
    -webkit-text-stroke: 6px #fff;
    paint-order: stroke;
}

.worries_item:nth-child(3) .worries_item_title {
    background-color: #efd4b6;
    color: #d98d34;
    -webkit-text-stroke: 6px #fff;
    paint-order: stroke;
}

.worries_item:nth-child(4) .worries_item_title {
    background-color: #b7cfe1;
    color: #1567a1;
    -webkit-text-stroke: 6px #fff;
    paint-order: stroke;
}

.worries_txt {
    padding: 15px 30px;
    line-height: calc(36 / 17);
}

.about {
    padding: 120px 0;
}

.about_wrapper {
    position: relative;
}

.about_wrap {
    width: 600px;
    margin-left: 450px;
    padding-top: 90px;
    position: relative;
}

.about_wrap::before {
    content: "";
    width: 138px;
    height: 162px;
    background: url(/images/top/illust_02.png) no-repeat bottom center / contain;
    position: absolute;
    top: 140px;
    right: -85px;
}

.about_title {
    margin-bottom: 45px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 38px;
    font-weight: 700;
    line-height: calc(76 / 38);
    letter-spacing: 0.16em;
}

.about_title .blue {
    color: #1567a1;
}

.about_title .pink {
    color: #d87990;
}


.about_title .pattern {
    position: relative;
}

.about_title .pattern::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 39px;
    background: url(/images/feature/pattern.jpg) repeat center;
    position: absolute;
    top: 10px;
    left: -3px;
    z-index: -1;
}

.about_txt {
    margin-bottom: 70px;
}

.about_img {
    position: absolute;
    top: 0px;
    left: calc(50% - 960px);
}

.about_img img {
    border-radius: 0 255px 255px 0;
}

.about_img::after {
    content: "";
    width: 301px;
    height: 274px;
    background: url(/images/top/about_02.png) no-repeat center / contain;
    position: absolute;
    right: 0;
    bottom: -250px;
    z-index: -1;
}

.area {
    padding-bottom: 200px;
    background: linear-gradient(180deg, #e0eff4 0%, rgba(255, 255, 255, 0%) 70%, rgba(255, 255, 255, 0%) 100%);
    position: relative;
}

.area::before {
    content: "";
    width: 100%;
    height: 236px;
    background: url(/images/top/bg_pattern.png) repeat;
    position: absolute;
    top: 0;
}

.area_title {
    margin-bottom: 50px;
    text-align: center;
}

.area_title .txt {
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
    position: relative;
}

.area_title .txt::before,
.area_title .txt::after {
    content: "";
    width: 35px;
    height: 38px;
    background: url(/images/top/title_deco.png) no-repeat center / contain;
    position: absolute;
}

.area_title .txt::before {
    left: -50px;
    bottom: 5px;
}

.area_title .txt::after {
    right: -50px;
    bottom: 5px;
    transform: scale(-1, 1);
}

.area_img {
    margin-left: 350px;
    margin-bottom: 10px;
    position: relative;
    z-index: 1;
}

.area_txt {
    margin-bottom: 50px;
    text-align: center;
}

.area_txt .marker {
    position: relative;
}

.area_txt .marker::before {
    content: "";
    width: calc(100% - 10px);
    height: 11px;
    background-color: #fff7bf;
    position: absolute;
    left: 0;
    bottom: 4px;
    z-index: -1;
}

.area_txt .bold {
    font-weight: 600;
}

.area_btn {
    margin: 0 auto;
}

.top-recruit {
    background: linear-gradient(150deg, #216cab 0%, #266cb1 21%, #3c79b5 54%, #5fb0d1 86%, #77bedb 100%);
    position: relative;
}

.top-recruit::after {
    content: "";
    width: 384px;
    height: 243px;
    background: url(/images/top/illust_03.png) no-repeat bottom / contain;
    position: absolute;
    right: calc(50% - 400px);
    bottom: 0;
}

.top-recruit_wrap {
    width: 570px;
}

.top-recruit_title {
    margin-bottom: 50px;
    font-family: "Zen Maru Gothic", sans-serif;
}

.top-recruit_title .txt {
    display: inline-block;
    padding: 12px 15px 17px 25px;
    border-radius: 10px;
    background-color: #fff;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: 1;
    color: #004b8b;
}

.top-recruit_title .txt:not(:last-child) {
    margin-bottom: 20px;
}

.top-recruit_txt {
    margin-bottom: 50px;
    color: #fff;
}

.top-recruit_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 320px;
    height: 70px;
    border-radius: 35px;
    border: 2px solid #fff;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
    position: relative;
}

.top-recruit_btn::after {
    content: "";
    width: 13px;
    height: 14px;
    background: url(/images/common/arw.png) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
}

.top-recruit_img {
    position: absolute;
    top: -100px;
    right: calc(50% - 810px);
}

.top-recruit_img img {
    border-radius: 100px;
}

.top-news_wrapper {
    position: relative;
}

.top-news_title {
    margin-bottom: 50px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
}

.top-news_title::after {
    content: "";
    display: block;
    width: 52px;
    height: 8px;
    margin-top: 15px;
    margin-left: 5px;
    background: url(/images/top/top-news_title_deco.png) no-repeat left / contain;
}

.top-news_wrap {
    width: 100%;
}

.top-news_btn {
    position: absolute;
    top: 0;
    right: 0;
}

/* feature
-------------------*/

.feature_item {
    display: flex;
    justify-content: space-between;
}

.feature_item:not(:last-child) {
    margin-bottom: 100px;
}

.feature_item:nth-child(even) {
    flex-direction: row-reverse;
}

.feature_item_img {
    width: 540px;
    height: 360px;
    position: relative;
}

.feature_item:nth-child(odd) .feature_item_img {
    margin-left: -100px;
}

.feature_item:nth-child(even) .feature_item_img {
    margin-right: -100px;
}

.feature_item_img::before {
    content: "";
    width: 540px;
    height: 360px;
    border-radius: 50px;
    background: rgba(21, 103, 161, 0.2);
    position: absolute;
    left: -14px;
    bottom: -14px;
    z-index: -1;
}

.feature_item_img img {
    border-radius: 50px;
}

.feature_item_wrap {
    width: 547px;
    margin-top: 90px;
}

.feature_item_title {
    margin-bottom: 30px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 38px;
    font-weight: 700;
    letter-spacing: 0.16em;
    line-height: calc(76 / 38);
    position: relative;
}

.feature_item_title::before {
    content: "";
    width: 218px;
    height: 233px;
    background: url(/images/feature/deco.png) no-repeat center / contain;
    position: absolute;
    top: -80px;
    left: -115px;
    z-index: -1;
}

.feature_item_title::after {
    content: "";
    display: block;
    width: 99%;
    height: 4px;
    margin-top: 18px;
    background: url(/images/common/dot.png) repeat left;
}

.feature_item_title .pattern {
    position: relative;
}

.feature_item_title .pattern::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 39px;
    background: url(/images/feature/pattern.jpg) repeat center;
    position: absolute;
    top: 10px;
    left: -3px;
    z-index: -1;
}


/* service
-------------------*/

.service_link_wrapper {
    margin-top: 120px;
}

.service_link_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 40px 60px;
}

.service_link_item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 510px;
    height: 70px;
    border-radius: 35px;
    background: linear-gradient(90deg, #2f8cbd, #7cc1dd);
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
    position: relative;
}

.service_link_item a::after {
    content: "";
    width: 14px;
    height: 14px;
    background: url(/images/service/arw.png) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%);
}

.service {
    width: 1280px;
    margin: 150px auto 0;
    padding-top: 0;
    border-radius: 50px;
    position: relative;
}

.service::before {
    content: "";
    width: 160px;
    height: 160px;
    position: absolute;
}

.service:last-of-type {
    margin-bottom: 100px;
}

.service:nth-of-type(1) {
    margin-top: 250px;
    background: rgba(239, 212, 182, 0.4);
}

.service:nth-of-type(2) {
    background: rgba(241, 218, 224, 0.4);
}

.service:nth-of-type(3) {
    background: rgba(201, 229, 198, 0.4);
}

.service:nth-of-type(4) {
    background: rgba(224, 239, 244, 0.4);
}

.service:nth-of-type(odd)::before {
    top: -115px;
    right: 135px;
}

.service:nth-of-type(even)::before {
    top: -115px;
    left: 135px;
}

.service:nth-of-type(1)::before {
    background: url(/images/service/illust_01.png) no-repeat center / contain;
}

.service:nth-of-type(2)::before {
    background: url(/images/service/illust_02.png) no-repeat center / contain;
}

.service:nth-of-type(3)::before {
    background: url(/images/service/illust_03.png) no-repeat center / contain;
}

.service:nth-of-type(4)::before {
    background: url(/images/service/illust_04.png) no-repeat center / contain;
}

.service_title {
    margin-bottom: 30px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 46px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-align: center;
    position: relative;
    top: -30px;
}

.service_title .txt {
    display: inline-block;
    position: relative;
}

.service_title .txt::before,
.service_title .txt::after {
    content: "";
    width: 35px;
    height: 38px;
    background: url(/images/service/title_deco.png) no-repeat center / contain;
}

.service_title .txt::before {
    position: absolute;
    bottom: 5px;
    left: -60px;
}

.service_title .txt::after {
    position: absolute;
    bottom: 5px;
    right: -60px;
    transform: scale(-1, 1);
}

.service:nth-of-type(1) .service_title {
    color: #d98d34;
}

.service:nth-of-type(2) .service_title {
    color: #d87990;
}

.service:nth-of-type(3) .service_title {
    color: #3b8b34;
}

.service:nth-of-type(4) .service_title {
    color: #1567a1;
}

.service_wrap:not(:last-of-type) {
    margin-bottom: 70px;
}

.service_wrap_title {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1080px;
    height: 50px;
    margin-bottom: 32px;
    border-radius: 10px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: 0.16em;
    color: #fff;
    position: relative;
}

.service_wrap_title::after {
    content: "";
    width: 26px;
    height: 11px;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    position: absolute;
    left: 50%;
    bottom: -10px;
    transform: translateX(-50%);
}

.service:nth-of-type(1) .service_wrap_title {
    background-color: #d98d34;
}

.service:nth-of-type(2) .service_wrap_title {
    background-color: #d87990;
}

.service:nth-of-type(3) .service_wrap_title {
    background-color: #3b8b34;
}

.service:nth-of-type(4) .service_wrap_title {
    background-color: #1567a1;
}

.service:nth-of-type(1) .service_wrap_title::after {
    background-color: #d98d34;
}

.service:nth-of-type(2) .service_wrap_title::after {
    background-color: #d87990;
}

.service:nth-of-type(3) .service_wrap_title::after {
    background-color: #3b8b34;
}

.service:nth-of-type(4) .service_wrap_title::after {
    background-color: #1567a1;
}

.service_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
}

.service_item {
    width: 510px;
    padding-left: 25px;
    padding-bottom: 5px;
    border-bottom: 1px solid;
    font-size: 20px;
    position: relative;
}

.service_item::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #1567a1;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}

.service_flow {
    display: flex;
    flex-wrap: wrap;
    gap: 50px 60px;
    margin-top: 50px;
}

.service_flow_item {
    width: 320px;
    height: 163px;
    padding: 15px 25px;
    border-radius: 30px;
    background-color: #fff;
    font-size: 18px;
    font-weight: 700;
    line-height: calc(36 / 18);
    letter-spacing: 0.05em;
    position: relative;
    counter-increment: number;
}

.service_flow_item .small {
    font-size: 15px;
    font-weight: 500;
}

.service_flow_item::before {
    content: counter(number, decimal-leading-zero)".";
    display: block;
    font-size: 20px;
    color: #1567a1;
}

.service_flow_item:not(:nth-child(3n))::after {
    content: "";
    width: 15px;
    height: 20px;
    background-color: #1567a1;
    clip-path: polygon(0 0, 0 100%, 100% 50%);
    position: absolute;
    top: 50%;
    right: -40px;
    transform: translateY(-50%);
}

.service_flow_item:last-child::after {
    content: none;
}

.service_flow_item .small {
    font-size: 15px;
    font-weight: 500;
}

.service_voice_list {
    margin-top: 60px;
}

.service_voice_item {
    display: flex;
    align-items: flex-start;
    gap: 60px;
}

.service_voice_item:not(:last-child) {
    margin-bottom: 50px;
}

.service_voice_item:nth-child(even) {
    margin-left: 220px;
}

.service_voice_wrap {
    text-align: center;
    position: relative;
}

.service_voice_img {
    width: 101px;
    height: 101px;
}

.service_voice_img img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}

.service_voice_info {
    font-size: 15px;
    letter-spacing: 0.05em;
    white-space: nowrap;
    color: #513f25;
    position: absolute;
    left: 50%;
    bottom: -45px;
    transform: translateX(-50%);
}

.service_voice_txt {
    width: 700px;
    min-height: 110px;
    padding: 40px 50px;
    border-radius: 30px;
    background-color: #fff;
    font-size: 16px;
    letter-spacing: 0.05em;
    line-height: calc(30 / 16);
    color: #513f25;
    position: relative;
}

.service_voice_txt::before {
    content: "";
    width: 18px;
    height: 22px;
    background-color: #1567a1;
    clip-path: polygon(100% 0, 0 50%, 100% 100%);
    position: absolute;
    top: 45px;
    left: -18px;
}


/* recruit
-------------------*/
.merit_wrapper {
    position: relative;
}

.merit_wrapper::before {
    content: "";
    width: 156px;
    height: 129px;
    background: url(/images/recruit/illust_01.png) no-repeat center / contain;
    position: absolute;
    top: -30px;
    right: 165px;
}

.merit_item {
    display: flex;
    align-items: flex-start;
    gap: 65px;
}

.merit_item:not(:last-child) {
    margin-bottom: 60px;
}

.merit_item:nth-child(even) {
    margin-left: 135px;
}

.merit_item_num {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: linear-gradient(120deg, #216cab 0%, #266cb1 20%, #77bedb 100%);
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 20px;
    letter-spacing: 0em;
    line-height: 1;
    color: #fff;
}

.merit_item_num .large {
    font-size: 60px;
    font-weight: 700;
    letter-spacing: 0.1em;
    transform: translateX(4px);
}

.merit_item_wrap {
    width: 700px;
    margin-top: 25px;
}

.merit_item_title {
    margin-bottom: 45px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 26px;
    font-weight: 700;
    letter-spacing: 0.1em;
    position: relative;
}

.merit_item_title::after {
    content: "";
    width: calc(100% + 75px);
    height: 4px;
    background: url(/images/common/dot.png) repeat left / contain;
    position: absolute;
    left: -75px;
    bottom: -25px;
}

.merit_item_txt {
    line-height: calc(36 / 17);
}

.business {
    background-color: #e0eff4;
    position: relative;
}

.business::after {
    content: "";
    width: 247px;
    height: 156px;
    background: url(/images/recruit/illust_02.png) no-repeat bottom center / contain;
    position: absolute;
    right: calc(50% - 640px);
    bottom: 0;
}

.business_title {
    margin-bottom: 110px;
}

.business_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 120px 0;
}

.business_item {
    width: 520px;
    padding: 60px 33px 35px 40px;
    background-color: #fff;
    border-radius: 30px;
    position: relative;
}

.business_item_title {
    display: block;
    width: 100%;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 26px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: calc(42 / 26);
    text-align: center;
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
}

.business_item_title::before,
.business_item_title::after {
    content: "";
    width: 35px;
    height: 38px;
    background: url(/images/recruit/title_deco.png) no-repeat center / contain;
    position: absolute;
}

.business_item_title::before {
    left: 20px;
    bottom: 10px;
}

.business_item_title::after {
    right: 20px;
    bottom: 10px;
    transform: scale(-1, 1);
}

.business_item_img {
    width: 152px;
    height: 152px;
    margin: 0 auto 40px;
}

.business_item_txt {
    line-height: calc(36 / 17);
}

.flow_list {
    position: relative;
}

.flow_list::before {
    content: "";
    width: 7px;
    height: 800px;
    background-color: #1567a1;
    position: absolute;
    top: 50px;
    left: 330px;
}

.flow_item {
    display: flex;
    align-items: center;
    padding-left: 390px;
    position: relative;
}

.flow_item:not(:last-child) {
    margin-bottom: 60px;
}

.flow_item::before {
    content: "";
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: #1567a1;
    position: absolute;
    left: 317px;
}

.flow_icon {
    margin-right: 40px;
}

.flow_time {
    width: 270px;
    font-size: 30px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1;
    color: #1567a1;
    text-align: right;
    position: absolute;
    top: 50%;
    left: 0px;
    transform: translateY(-50%);
}

.flow_txt {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1;
}

.recruit {
    background: linear-gradient(180deg, #e0eff4 0%, rgba(255, 255, 255, 0) 100%);
}

.recruit_list {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 30px 60px;
    margin-bottom: 120px;
}

.recruit_list_item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 510px;
    min-height: 70px;
    padding: 20px 40px;
    border-radius: 35px;
    background: linear-gradient(120deg, #2f8cbd 0%, #2f8cbd 5%, #5aabcd 55%, #7cc1dd 100%);
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.5;
    color: #fff;
    position: relative;
}

.recruit_list_item a::after {
    content: "";
    width: 14px;
    height: 14px;
    background: url(/images/recruit/arw.png) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%);
}

.recruit_item:not(:last-child) {
    margin-bottom: 120px;
}

.recruit_item_title {
    margin-bottom: 50px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 38px;
    font-weight: 700;
    letter-spacing: 0.16em;
}

.recruit_item_title::after {
    content: "";
    display: block;
    width: 100%;
    height: 4px;
    margin-top: 20px;
    background: url(/images/common/dot.png) repeat left;
}

.recruit_item td {
    background-color: #e0eff4;
}


/* info
-------------------*/

.greeting_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.greeting_img {
    position: relative;
}

.greeting_img::before {
    content: "";
    width: 400px;
    height: 360px;
    border-radius: 50px;
    background: rgba(21, 103, 161, 0.2);
    position: absolute;
    left: -14px;
    bottom: -14px;
    z-index: -1;
}

.greeting_img img {
    border-radius: 50px;
    border: 5px solid #e0eff4;
}

.greeting_txt {
    width: 600px;
    margin-top: -15px;
}

.greeting_txt .name {
    display: block;
    text-align: right;
}

.info {
    margin-bottom: 100px;
    background-color: #e0eff4;
}

.info_item:not(:last-child) {
    margin-bottom: 130px;
}

.info_item_title {
    margin-bottom: 50px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 38px;
    font-weight: 700;
    letter-spacing: 0.16em;
}

.info_item_title::after {
    content: "";
    display: block;
    width: 100%;
    height: 4px;
    margin-top: 20px;
    background: url(/images/common/dot.png) repeat left;
}

.info_map {
    width: 100%;
    height: 300px;
    margin-top: 85px;
}

.info_map iframe {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/* footer
-------------------*/
.footer {
    overflow: hidden;
}

.f-box {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 1620px;
    height: 447px;
    padding: 100px 270px;
    border-radius: 50px;
    background-color: #e0eff4;
    position: relative;
    left: calc(50% - 810px);
}

.f-logo {
    margin-bottom: 55px;
}

.f-cmn-tel {
    margin-bottom: 40px;
}

.f-cmn-mail {
    width: 252px;
}

.f-nav {
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1;
    color: #0d0d0d;
}

.f-nav_list {
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    flex-wrap: wrap;
    gap: 32px 45px;
    width: 400px;
    height: 190px;
    padding: 15px 0;
}

.f-nav_link {
    position: relative;
}

.f-nav_link::before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 9px;
    margin-right: 10px;
    transform: translateY(-1px);
    background: url(/images/common/f-arw.png) no-repeat center / contain;
}

.f-bottom {
    width: 100%;
}

.f-bottom::after {
    content: "";
    display: block;
    width: 100%;
    height: 14px;
    background: linear-gradient(90deg, #2f8cbd, #7cc1dd);
}

.f-bottom_wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 140px;
    padding-left: 70px;
    padding-right: 30px;
    font-size: 12px;
    letter-spacing: 0.05em;
    line-height: 1;
}

.f-sub-nav_list {
    display: flex;
    gap: 35px;
}

.f-sub-nav_link {
    position: relative;
}

.f-sub-nav_item:not(:last-child) .f-sub-nav_link::after {
    content: "|";
    position: absolute;
    top: -1px;
    right: -20px;
}

/*# sourceMappingURL=style.css.map */