/* ------------------------------------------------------
content
------------------------------------------------------ */
.pages #content .section:not(:last-child) {
    padding: 0 0px 55px 0;
}

.pages #content .section .section {
    padding-top: 30px;
}

.pages #content .section p:last-child {
    margin-bottom: 0;
}

.pages .contents_detail {
    letter-spacing: 0.1em;
    line-height: 2.5;
    text-align: justify;
}

.pages .contents_detail p:not(:last-child) {
    margin-bottom: 40px;
}

.pages .contents_detail a {
    text-decoration: underline;
}

.pages .contents_detail .hasimg {
    line-height: 0;
}

.pages .contents_detail ul li,
.pages .contents_detail ol li {
    list-style: inherit;
    margin-left: 15px;
}

.pages .contents_detail .wp-block-image {
    margin-bottom: 47px;
}

/* ------------------------------------------------------
h3 h4 h5 h6
------------------------------------------------------ */
.pages h3,
.pages h4,
.pages h5,
.pages h6 {
    font-weight: 700;
}

.pages h3.under_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    color: var(--blue-color);
    margin-bottom: 40px;
}

.pages h3.under_title span {
    display: block;
    font-size: 14px;
    letter-spacing: 0.1em;
    margin-bottom: 2px;
}

/* ------------------------------------------------------
p_mainvisual
------------------------------------------------------ */
.pages #p_mainvisual {
    width: 100%;
    height: 500px;
    font-family: var(--ZenMaruGothic-font);
    padding-left: 150px;
    position: relative;
}

.pages #p_mainvisual .p_mv_component {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-top: 104px;
    position: relative;
    z-index: 1;
}

.pages #p_mainvisual h2 {
    width: 100%;
    max-width: 386px;
    height: 127px;
    font-size: 40px;
    font-weight: 500;
    letter-spacing: 0.1em;
    background: var(--white-color);
    border-top-right-radius: 40px;
    padding-top: 39px;
    position: relative;
}

.pages #p_mainvisual h2::before,
.pages #p_mainvisual h2::after {
    position: absolute;
    content: '';
    background-image: url(../images/common/corner01.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 40px;
    height: 40px;
}

.pages #p_mainvisual h2::before {
    top: -40px;
    left: 100px;
}

.pages #p_mainvisual h2::after {
    bottom: 0;
    right: -40px;
}

.pages #p_mainvisual h2 span {
    display: block;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-top: 4px;
}

.pages #p_mainvisual .p_mv_txt {
    font-weight: 500;
    line-height: 2.43;
    margin-bottom: 35px;
}

.pages #p_mainvisual .p_mv_cover {
    width: 100%;
    height: 100%;
    background: var(--white-color);
    padding-left: 250px;
    position: absolute;
    top: 0;
    right: 0;
    overflow: hidden;
}

.pages #p_mainvisual .p_mv_cover::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.2);
    border-top-left-radius: 40px;
    border-bottom-left-radius: 40px;
    top: 0;
    left: 0;
    pointer-events: none;
}

.pages #p_mainvisual .p_mv_cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-top-left-radius: 40px;
    border-bottom-left-radius: 40px;
}

.pages #p_mainvisual h2,
.pages #p_mainvisual .p_mv_txt,
.pages #p_mainvisual .p_mv_cover {
    opacity: 0;
    transform: translateY(20px);
    transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.pages #p_mainvisual.active h2,
.pages #p_mainvisual.active .p_mv_txt,
.pages #p_mainvisual.active .p_mv_cover {
    opacity: 1;
    transform: translateY(0);
}

.pages #p_mainvisual.active .p_mv_txt {
    transition-delay: .5s;
}

/* ------------------------------------------------------
topic_path
------------------------------------------------------ */
.pages #topic_path {
    margin: 0 0 67px;
}

.pages #topic_path ul {
    padding: 38px 0 0;
}

.pages #topic_path li {
    display: inline-block;
    color: #3e3a39;
    font-size: 14px;
    line-height: 1.4;
}

.pages #topic_path li a {
    text-decoration: underline;
    color: #e06277;
}

.pages #topic_path li a:hover {
    text-decoration: none;
}

/* ------------------------------------------------------
table
------------------------------------------------------ */
.pages table {
    margin-bottom: 25px;
}

.pages table th,
.pages table td {
    font-size: 15px;
    line-height: 1.73;
    letter-spacing: 0.1em;
    padding: 21px 10px 22px 25px;
    border: 1px solid #b3b3b3;
}

.pages table th {
    width: 25%;
    font-weight: 500;
    color: var(--white-color);
    background: var(--blue-color);
    text-align: left;
}

.pages table.td_top td {
    vertical-align: top;
}

.pages table.td_center td {
    text-align: center;
}

.pages table.tb_fix {
    table-layout: fixed;
}

.pages table.tb_block td {
    border-left: 0;
    border-top: 0;
    padding-left: 33px;
}

.pages table.tb_block th {
    vertical-align: top;
    border-left: 0;
    border-right: 0;
    border-bottom-color: var(--white-color);
}

.pages table.tb_block tr:first-child th {
    border-top: 1px solid var(--blue-color);
}

.pages table.tb_block tr:last-child th {
    border-bottom-color: var(--blue-color);
}

.pages table.tb_block tr:first-child td {
    border-top: 1px solid #b3b3b3;
}

.pages #content table:last-child {
    margin-bottom: 0;
}

.pages table td a {
    text-decoration: underline;
}

.pages table td ol li,
.pages table td ul li {
    list-style: inherit;
    margin-left: 15px;
}

/*-----txt_note-----*/
.pages .txt_note {
    display: none;
}

.pages .txt_bold {
    font-weight: 700;
}

/* ------------------------------------------------------
under list
------------------------------------------------------ */
.pages .list01 li {
    margin-bottom: 22px;
    padding-left: 35px;
    position: relative;
}

.pages .list01 li::before {
    position: absolute;
    content: "";
    width: 20px;
    height: 3px;
    background: #1e3c72;
    top: 9px;
    left: 0;
}

.pages .list_check li {
    margin-bottom: 22px;
    padding-left: 35px;
    position: relative;
}

.pages .list_check li::before {
    position: absolute;
    content: "";
    width: 7px;
    height: 12px;
    border: solid #1e3c72;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    display: inline-block;
    top: 8px;
    left: 0;
}

.pages .list01:last-child,
.pages .list01 li:last-child,
.pages .list_check:last-child,
.pages .list_check li:last-child {
    margin-bottom: 0px;
}

/* ------------------------------------------------------
under frame
------------------------------------------------------ */
.pages .frame01 {
    background: rgba(255, 211, 216, 0.3);
    padding: 25px 30px 25px;
    margin: 0 auto 30px;
    border-radius: 10px;
    box-sizing: border-box;
}

.pages .frame01:last-child {
    margin: 0 auto;
}

/* ------------------------------------------------------
under_step
------------------------------------------------------ */
.pages .under_step dl {
    margin-bottom: 60px;
}

.pages .under_step dl:last-child {
    margin-bottom: 0px;
}

.pages .under_step dl dt {
    font-size: 18px;
    color: #fff;
    background: #e06277;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border: 2px solid #e06277;
    padding: 10px 20px 5px;
    box-sizing: border-box;
}

.pages .under_step dl dt span {
    font-family: 'Lato', sans-serif;
    font-weight: 700;
    margin-right: 5px;
}

.pages .under_step dl dd {
    display: flex;
    align-items: center;
    border: 2px solid #e06277;
    padding: 20px;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}

.pages .under_step dl:nth-child(odd) dd {
    flex-direction: row-reverse;
}

.pages .under_step dl dd .step_img {
    flex-shrink: 0;
    padding-left: 40px;
    margin-bottom: 0 !important;
    box-sizing: border-box;
}

.pages .under_step dl:nth-child(even) dd .step_img {
    padding: 0 40px 0 0;
}

/* ------------------------------------------------------
qa_dl
------------------------------------------------------ */
.pages .qa_dl dl {
    padding-left: 80px;
    padding-bottom: 60px;
    position: relative;
    z-index: 1;
    box-sizing: border-box;
}

.pages .qa_dl dl:after {
    position: absolute;
    z-index: -1;
    left: 25px;
    top: 0;
    height: 100%;
    width: 1px;
    content: '';
    display: block;
    border-left: rgba(119, 119, 119, 0.30) 1px dotted;
}

.pages .qa_dl dl:last-child {
    padding-bottom: 0;
}

.pages .qa_dl dl dt,
.pages .qa_dl dl dd {
    position: inherit;
    z-index: 1;
}

.pages .qa_dl dl dt span,
.pages .qa_dl dl dd span {
    position: absolute;
    z-index: 1;
    left: -80px;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    color: #fff;
    font-size: 18px;
}

.pages .qa_dl dl dt {
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: bold;
    color: #00478A;
    min-height: 50px;
    display: flex;
    align-items: center;
    line-height: 1.4em;
}

.pages .qa_dl dl dd {
    padding: 30px;
    background: rgba(109, 178, 216, 0.15);
}

/* ------------------------------------------------------
under_bnr
------------------------------------------------------ */
.pages .under_bnr_full {
    background: url(../images/under_btn_bg.jpg) no-repeat center;
    background-size: cover;
    width: 700px;
    height: 150px;
    border-radius: 8px;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.25);
    margin: 0 auto;
    transition: all 0.25s linear;
}

.pages .under_bnr_full a {
    font-size: 18px;
    line-height: 1.6;
    color: #fff;
    width: 100%;
    height: 100%;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 .5em;
}

/* ------------------------------------------------------
others
------------------------------------------------------ */
.pages .center {
    margin-bottom: 35px;
}

.pages .image_l {
    margin: 0 40px 15px 0;
}

.pages .image_r {
    margin: 0 0 15px 40px;
}

.pages .a_hover:hover {
    text-decoration: none;
}

.pages .wp-pagenavi {
    display: flex;
    justify-content: center;
    flex-flow: row wrap;
    gap: 10px;
}

.pages .wp-pagenavi span,
.pages .wp-pagenavi a {
    font-family: var(--ZenMaruGothic-font);
    font-size: 18px;
    font-weight: 500;
    color: var(--blue-color);
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    border-radius: 50%;
    border: 1px solid var(--blue-color);
    background: var(--white-color);
    padding: 0 5px 4px;
    margin: 0 0 10px;
    position: relative;
}

.pages .wp-pagenavi a,
.pages .wp-pagenavi a:link,
.pages .wp-pagenavi a:visited {
    transition: all .3s ease;
    position: relative;
}

.pages .wp-pagenavi .current {
    color: var(--white-color);
    background: var(--blue-color);
    border-color: var(--blue-color);
    position: relative;
}

.pages .wp-pagenavi a.previouspostslink,
.pages .wp-pagenavi a.nextpostslink {
    border-color: var(--blue-color);
    color: transparent;
}

.pages .wp-pagenavi a.nextpostslink::before,
.pages .wp-pagenavi a.nextpostslink::after,
.pages .wp-pagenavi a.previouspostslink::before,
.pages .wp-pagenavi a.previouspostslink::after {
    position: absolute;
    content: '';
    background-image: url(../images/common/icon_arrow02.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 19px;
    height: 12px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all .3s ease;
}

.pages .wp-pagenavi a.nextpostslink::after {
    transform: translate(-70%, -50%);
    opacity: 0;
}

.pages .wp-pagenavi a.previouspostslink::before,
.pages .wp-pagenavi a.previouspostslink::after {
    transform: translate(-50%, -50%) rotate(-180deg);
}

.pages .wp-pagenavi a.previouspostslink::after {
    transform: translate(-30%, -50%) rotate(-180deg);
    opacity: 0;
}

@keyframes arrow_animation3 {
    0% {
        transform: translate3d(-50%, -50%, 0) rotate(-180deg);
        opacity: 1;
    }

    70% {
        opacity: 0;
    }

    100% {
        transform: translate3d(-20%, -50%, 0) rotate(-180deg);
        opacity: 0;
    }
}

@keyframes arrow_animation4 {
    0% {
        transform: translate3d(-30%, -50%, 0) rotate(-180deg);
        opacity: 0;
    }

    100% {
        transform: translate3d(-50%, -50%, 0) rotate(-180deg);
        opacity: 1;
    }
}

.pages .wp-pagenavi .pages,
.pages .wp-pagenavi .first,
.pages .wp-pagenavi .last {
    display: none;
}

.pages .btn_back {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.pages .btn_back li:not(.special-btn) {
    font-size: 13px;
    font-weight: 300;
    padding-top: 10px;
}

.pages .btn_back li:not(.special-btn) a {
    letter-spacing: 0.1em;
    color: #b3b3b3;
    display: inline-flex;
    align-items: center;
    transition: all .3s ease;
}

.pages .btn_back li:not(.special-btn) a i {
    display: inline-block;
    background-repeat: no-repeat;
    background-size: 100% auto;
    width: 39px;
    height: 11px;
    position: relative;
    top: -4px;
}

.pages .btn_back li.prev-btn {
    margin-right: 93px;
}

.pages .btn_back li.prev-btn a i {
    background-image: url(../images/common/prev_icon.svg);
    margin-right: 7px;
}

.pages .btn_back li.next-btn {
    margin-left: 93px;
}

.pages .btn_back li.next-btn a i {
    background-image: url(../images/common/next_icon.svg);
    margin-left: 7px;
}

.pages .btn_back li.special-btn {
    width: 303px;
}

.pages .btn_back li.special-btn .btn_primary a {
    text-transform: uppercase;
}

/* ------------------------------------------------------
p_blog
------------------------------------------------------ */
.pages .p_blog #p_mainvisual h2 i {
    background-image: url(../images/top/idx_about_decor01.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 140px;
    height: 214px;
    position: absolute;
    top: 0;
    right: -40px;
    z-index: 1;
    pointer-events: none;
}

.pages #blog_info {
    padding: 108px 0 50px;
}

.pages #blog_info .blog_info_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 68px;
}

.pages #blog_info .blog_cate_list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.pages #blog_info .blog_cate_list li {
    width: calc((100% - 30px) / 4);
    height: 60px;
}

.pages #blog_info .blog_cate_list li a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    letter-spacing: 0.1em;
    color: #fbb03b;
    border: 1px solid #fbb03b;
    border-radius: 30px;
    transition: all .3s ease;
}

.pages #blog_info .blog_cate_list li.active a {
    color: var(--white-color);
    background: #fbb03b;
}

.pages .blog_wrap {
    padding: 70px 0 115px;
}

.pages .blog_wrap .blog_list {
    display: flex;
    flex-wrap: wrap;
    gap: 42px;
    margin-bottom: 38px;
}

.pages .blog_wrap .blog_list .blog_card {
    width: calc((100% - 84px) / 3);
    margin-bottom: 43px;
}

.pages .blog_wrap .blog_list .blog_card figure {
    width: 100%;
    height: 18.78vw;
    max-height: 240px;
    border-radius: 10px;
    margin-bottom: 30px;
    overflow: hidden;
}

.pages .blog_wrap .blog_list .blog_card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.pages .blog_wrap .blog_list .blog_card .card_meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    font-size: 14px;
    font-weight: 400;
    margin-bottom: 15px;
}

.pages .blog_wrap .blog_list .blog_card .cate_group {
    margin-bottom: 0;
}

.pages .blog_wrap .blog_list .blog_card .cate_group span {
    display: inline-block;
    letter-spacing: 0;
    color: var(--white-color);
    background: #fbb03b;
    border-radius: 15px;
    padding: 5px 21px;
    margin: 0 5px 5px 0;
}

.pages .blog_wrap .blog_list .blog_card .card_date {
    letter-spacing: 0;
    margin-top: 5px;
}

.pages .blog_wrap .blog_list .blog_card .card_title {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.75;
    color: var(--blue-color);
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
    margin-bottom: 13px;
}

.pages .blog_wrap .blog_list .blog_card .card_txt {
    line-height: 2;
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
}

.pages .media_wrap {
    width: 94%;
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
    gap: 60px;
    padding: 160px 0 115px;
    margin: 0 auto;
}

.pages .media_wrap .side_navi {
    width: 100%;
    max-width: 280px;
    font-family: var(--ZenMaruGothic-font);
}

.pages .media_wrap .side_navi dl {
    margin-bottom: 51px;
}

.pages .media_wrap .side_navi dl:last-child {
    margin-bottom: 0;
}

.pages .media_wrap .side_navi dl dt {
    font-size: 24px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-bottom: 15px;
}

.pages .media_wrap .side_navi dl dt span {
    display: block;
    font-size: 12px;
    letter-spacing: 0.1em;
    margin-top: 1px;
}

.pages .media_wrap .side_navi dl dd .list_taxo {
    border: 2px solid var(--blue-color);
    border-radius: 10px;
}

.pages .media_wrap .side_navi dl dd .list_taxo li {
    width: 100%;
    height: 60px;
}

.pages .media_wrap .side_navi dl dd .list_taxo li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    padding: 0 10px 0 28px;
    border-bottom: 2px solid var(--blue-color);
    transition: all .3s ease;
}

.pages .media_wrap .side_navi dl dd .list_taxo li:last-child a {
    border-bottom: 0;
}

.pages .media_wrap .details_wrap {
    width: 100%;
    flex: 1;
}

.pages .details_wrap .main_photo {
    width: 100%;
    margin-bottom: 24px;
}

.pages .details_wrap .main_photo img {
    width: 100%;
    border-radius: 10px;
}

.pages .details_wrap .media_headline {
    margin-bottom: 41px;
}

.pages .details_wrap .media_meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    font-size: 14px;
    margin-bottom: 18px;
}

.pages .details_wrap .media_meta p {
    letter-spacing: 0;
}

.pages .details_wrap .media_meta .media_gr_cate {
    margin: 0 25px 0 0;
}

.pages .details_wrap .media_meta .media_gr_cate span {
    display: inline-block;
    letter-spacing: 0;
    color: var(--white-color);
    background: #fbb03b;
    border-radius: 15px;
    padding: 5px 21px;
    margin: 0 5px 5px 0;
}

.pages .details_wrap .media_meta .media_date {
    padding-bottom: 5px;
}

.pages .details_wrap .media_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
}

.pages .details_wrap .contents_detail {
    margin-bottom: 68px;
}

.pages .details_wrap .btn_primary {
    text-align: center;
}

.pages .related_blog {
    padding-bottom: 113px;
}

.pages .related_blog .related_blog_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-bottom: 50px;
}

.pages .related_blog .related_blog_title span {
    display: block;
    font-size: 14px;
    letter-spacing: 0.1em;
    margin-bottom: 5px;
}

.pages .related_blog .blog_list {
    display: flex;
    gap: 30px;
}

.pages .related_blog .blog_list .blog_card {
    width: calc((100% - 60px) / 3);
}

.pages .related_blog .blog_list .blog_card figure {
    width: 100%;
    height: 18.79vw;
    max-height: 240px;
    border-radius: 10px;
    margin-bottom: 30px;
    overflow: hidden;
}

.pages .related_blog .blog_list .blog_card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.pages .related_blog .blog_list .blog_card .card_meta {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    font-size: 14px;
    font-weight: 400;
    margin-bottom: 15px;
}

.pages .related_blog .blog_list .blog_card .cate_group {
    margin-bottom: 0;
}

.pages .related_blog .blog_list .blog_card .cate_group span {
    display: inline-block;
    letter-spacing: 0;
    color: #fbb03b;
    background: var(--white-color);
    border: 1px solid #fbb03b;
    border-radius: 15px;
    padding: 4px 21px;
    margin: 0 5px 5px 0;
}

.pages .related_blog .blog_list .blog_card .card_date {
    letter-spacing: 0;
    margin-top: 5px;
}

.pages .related_blog .blog_list .blog_card .card_title {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.75;
    color: var(--blue-color);
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
    margin-bottom: 13px;
}

/* ------------------------------------------------------
p_contact
------------------------------------------------------ */
.pages .p_contact #p_mainvisual h2 i {
    background-image: url(../images/footer/contact_decor01.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 141px;
    height: 143px;
    position: absolute;
    top: 80px;
    right: -67px;
    z-index: 1;
    pointer-events: none;
}

.pages #contact_info {
    padding: 120px 0 0;
}

.pages #contact_info .contact_wrap {
    background: #e4f7f9;
    padding: 120px 3% 180px;
    position: relative;
    z-index: 1;
}

.pages #contact_info .contact_decor {
    position: absolute;
    background-image: url(../images/contact/decor01.png);
    background-repeat: repeat-y;
    background-position: top 133px center;
    background-size: contain;
    width: 1776px;
    height: 100%;
    top: 0;
    left: 54%;
    transform: translateX(-50%);
    z-index: -1;
}

.pages #contact_info .catcher_layer {
    max-width: 1200px;
    background: var(--white-color);
    border-radius: 20px;
    padding: 107px 0 0;
    z-index: 1;
}

.pages #contact_info .inner {
    max-width: 800px;
}

.pages #contact_info .contact_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 17px;
}

.pages #contact_info .box_contact_phone {
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--blue-color);
}

.pages #contact_info .box_contact_phone dt {
    width: 71px;
    height: 71px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: var(--blue-color);
    margin-right: 20px;
    flex-shrink: 0;
}

.pages #contact_info .box_contact_phone dt i {
    display: inline-block;
    background-image: url(../images/contact/icon_phone.png);
    background-size: contain;
    width: 40px;
    height: 40px;
}

.pages #contact_info .box_contact_phone a {
    font-size: 40px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.05;
    color: var(--blue-color);
    margin-right: 19px;
}

.pages #contact_info .box_contact_phone .box_contact_notes {
    font-size: 14px;
    letter-spacing: 0.05em;
    margin-bottom: 0;
}

.pages #contact_box {
    padding: 77px 0 99px;
}

.pages #contact_box .smf-form--letter .smf-item {
    padding: 0 0 37px;
}

.pages #contact_box .smf-form--letter .smf-item__col--label {
    display: flex;
    align-items: center;
}

.pages #contact_box .smf-item__label {
    font-family: var(--ZenMaruGothic-font);
    margin-right: 15px;
}

.pages #contact_box .smf-item__label__text {
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
}

.pages #contact_box .smf-item__description {
    width: 50px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.1em;
    background: #fbb03b;
    color: var(--white-color);
    border-radius: 10px;
    margin: 0 0;
}

.pages #contact_box .smf-radio-buttons-control .smf-label {
    margin-bottom: 11px;
}

.pages #contact_box .smf-radio-buttons-control .smf-label:last-child {
    margin-bottom: 0;
}

.pages #contact_box .smf-form .smf-radio-button-control {
    gap: 21px;
}

.pages #contact_box .smf-form .smf-radio-button-control__control {
    width: 20px;
    height: 20px;
    border-color: var(--blue-color);
    margin-top: 4px;
}

.pages #contact_box .smf-form .smf-radio-button-control__control:before {
    width: 14px;
    height: 14px;
    background-color: var(--blue-color);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.pages #contact_box .smf-form .smf-radio-button-control__control:checked {
    background-color: var(--white-color);
    border-color: var(--blue-color);
}

.pages #contact_box .smf-radio-button-control__label,
.pages #contact_box .smf-checkbox-control__label {
    font-family: var(--main-font);
    font-size: 16px;
    letter-spacing: 0.1em;
}

.pages #contact_box .input_custom,
.pages #contact_box .txt_custom {
    width: 100%;
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: 0.1em;
    border: 1px solid var(--blue-color);
    border-radius: 4px;
    padding: 8px 23px 10px;
}

.pages #contact_box .input_custom {
    height: 60px;
}

.pages #contact_box .txt_custom {
    height: 240px;
    text-align: justify;
    resize: none;
}

.pages #contact_box input::placeholder,
.pages #contact_box textarea::placeholder {
    font-size: 16px;
    letter-spacing: 0.1em;
    color: #ccc;
}

.pages #contact_box .field_privacy .smf-item__col--label {
    padding-bottom: 3px;
}

.pages #contact_box .field_privacy .privacy_txt {
    font-size: 14px;
    line-height: 2.86;
    text-align: justify;
    margin-bottom: 6px;
}

.pages #contact_box .field_privacy .smf-placeholder {
    text-align: center;
}

.pages #contact_box .smf-form .field_privacy .smf-checkbox-control {
    gap: 20px;
}

.pages #contact_box .smf-form .field_privacy .smf-checkbox-control__control {
    width: 24px;
    height: 24px;
    border-color: var(--blue-color);
    border-radius: 4px;
    margin-top: 2px;
}

.pages #contact_box .smf-form .field_privacy .smf-checkbox-control__control:before {
    width: 6px;
    height: 10px;
    border-width: 0 1px 1px 0;
    top: calc(50% - 7px);
}

.pages #contact_box .smf-form .field_privacy .smf-checkbox-control__control:checked {
    background-color: var(--blue-color);
    border-color: var(--blue-color);
}

.pages #contact_box .smf-action {
    margin: 56px 0 0;
}

.pages #contact_box .smf-action .smf-button-control {
    display: block;
    width: 100%;
    max-width: 260px;
    height: 60px;
    margin: 0 auto 20px;
}

.pages #contact_box .smf-action .smf-button-control__control {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: var(--ZenMaruGothic-font);
    font-weight: 500;
    letter-spacing: 0.05em;
    color: var(--white-color);
    background: var(--blue-color);
    border-radius: 30px;
    border: 2px solid var(--blue-color);
    transition: all .3s ease;
}

.pages #contact_box .snow-monkey-form[data-screen="confirm"] .field_privacy {
    display: none;
}

.pages #contact_box .smf-complete-content {
    font-weight: 500;
    text-align: center;
}

/* ------------------------------------------------------
p_gallery
------------------------------------------------------ */
.pages .p_gallery #p_mainvisual h2 i {
    background-image: url(../images/top/idx_service_decor02.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 201px;
    max-width: 201px;
    height: 126px;
    max-height: 126px;
    position: absolute;
    top: 55px;
    right: -150px;
    z-index: 1;
    pointer-events: none;
}

.pages #gallery_info {
    padding: 107px 0 105px;
}

.pages #gallery_info .gallery_info_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 82px;
}

.pages #gallery_info .tab_btns {
    width: 100%;
    max-width: 1000px;
    display: flex;
    margin: 0 auto 130px;
}

.pages #gallery_info .tab_btns .tab-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50%;
    height: 70px;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    color: var(--blue-color);
    border: 2px solid var(--blue-color);
    padding: 0 8px;
    position: relative;
    cursor: pointer;
}

.pages #gallery_info .tab_btns .tab-button::after {
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-top: 18px solid var(--blue-color);
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    opacity: 0;
    visibility: hidden;
}

.pages #gallery_info .tab_btns .tab-button:first-child {
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}

.pages #gallery_info .tab_btns .tab-button:last-child {
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
}

.pages #gallery_info .tab_btns .tab-button.is-active {
    color: var(--white-color);
    background: var(--blue-color);
}

.pages #gallery_info .tab_btns .tab-button.is-active::after {
    opacity: 1;
    visibility: visible;
}

.pages #gallery_info .gallery_container .gallery_box.is-hidden {
    display: none;
}

.pages #gallery_info .gallery_list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

.pages #gallery_info .gallery_list .gallery_item {
    width: calc((100% - 60px) / 3);
    margin-bottom: 36px;
}

.pages #gallery_info .gallery_item .gallery_image {
    width: 100%;
    margin-bottom: 15px;
}

.pages #gallery_info .gallery_item .gallery_image a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #b3b3b3;
    border-radius: 10px;
    padding: 0 35px;
    position: relative;
    overflow: hidden;
}

.pages #gallery_info .gallery_item .gallery_image a::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    top: 0;
    left: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity .6s ease;
}

.pages #gallery_info .gallery_item .gallery_image .gallery_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 18px;
    font-weight: 700;
    line-height: 1.78;
    color: var(--white-color);
    text-align: center;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
    opacity: 0;
    transition: all .6s ease;
}

.pages #gallery_info .gallery_item .gallery_image figure {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

.pages #gallery_info .gallery_item .gallery_image figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: translateZ(0);
    transition: transform .6s ease;
}

.pages #gallery_info .gallery_item .author_name {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    color: var(--blue-color);
}

.pages .gallery_contents {
    padding: 130px 0 100px;
}

.pages .gallery_contents .author_name {
    text-align: center;
    margin-bottom: 60px;
}

.pages .gallery_contents .author_name span {
    display: inline-block;
    min-width: 412px;
    font-size: 30px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--white-color);
    background: var(--blue-color);
    border-radius: 10px;
    padding: 21px 35px 24px;
}

.pages .gallery_contents .main_image {
    width: 65.972vw;
    max-width: 380px;
    height: 65.972vw;
    max-height: 380px;
    border: 1px solid #b3b3b3;
    border-radius: 10px;
    margin: 0 auto 94px;
    overflow: hidden;
}

.pages .gallery_contents .main_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pages .gallery_contents .gallery_thumbnail {
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
    margin-bottom: 94px;
}

.pages .gallery_contents .gallery_thumbnail li {
    width: calc((100% - 200px) / 5);
}

.pages .gallery_contents .gallery_thumbnail li a {
    width: 100%;
    height: 100%;
    display: block;
    border: 1px solid #b3b3b3;
    border-radius: 10px;
    overflow: hidden;
}

.pages .gallery_contents .gallery_thumbnail li a img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: translateZ(0);
    transition: transform .6s ease;
}

.pages .gallery_contents .btn_primary {
    text-align: center;
}

.pages#gallery .vbox-content {
    padding: 20px 10%;
}

.pages#gallery .vbox-child {
    width: 100%;
    max-width: 900px !important;
    height: 53.619vw;
    max-height: 600px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 5px 5px;
    box-shadow: 0 0;
}

.pages#gallery .vbox-child img {
    max-height: 100%;
    flex-shrink: 0;
}

.pages#gallery .vbox-next,
.pages#gallery .vbox-prev {
    width: 30px;
    height: 30px;
}

.pages#gallery .vbox-next {
    right: calc(50% - 485px);
}

.pages#gallery .vbox-prev {
    left: calc(50% - 500px);
}

.pages#gallery .vbox-next span,
.pages#gallery .vbox-prev span {
    width: 100%;
    height: 100%;
    border: 3px solid #fff;
    border-left: 0;
    border-top: 0;
    position: relative;
    top: auto;
}

.pages#gallery .vbox-next span {
    transform: rotate(315deg);
}

.pages#gallery .vbox-prev span {
    transform: rotate(135deg);
}

.pages#gallery .vbox-close {
    font-size: 30px;
    color: #fff;
    padding: 0 0;
    top: 2vw;
    right: 2vw;
}

/* ------------------------------------------------------
p_staff
------------------------------------------------------ */
#staff #footer .box_contact {
    background: #e4f7f9;
}

#staff #footer .box_contact .inner {
    z-index: 1;
}

.pages .p_staff #p_mainvisual h2 i {
    background-image: url(../images/top/idx_about_decor03.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 173px;
    height: 220px;
    position: absolute;
    bottom: -105px;
    right: -125px;
    z-index: 1;
    pointer-events: none;
}

.pages .p_staff #content {
    padding: 122px 0 0;
}

.pages .p_staff .staff_wrap {
    background: #e4f7f9;
    padding: 108px 0 41px;
    position: relative;
}

.pages .p_staff .staff_wrap .staff_info_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 107px;
}

.pages .p_staff .staff_wrap .staff_list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

.pages .p_staff .staff_wrap .staff_card {
    width: calc((100% - 60px) / 3);
    margin-bottom: 38px;
}

.pages .p_staff .staff_wrap .staff_card figure {
    width: 100%;
    height: 18.78vw;
    max-height: 240px;
    border-radius: 10px;
    margin-bottom: 6px;
    overflow: hidden;
}

.pages .p_staff .staff_wrap .staff_card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.pages .p_staff .staff_wrap .staff_card dl {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 5px;
    color: var(--blue-color);
    margin-bottom: 14px;
}

.pages .p_staff .staff_wrap .staff_card dl dt {
    font-size: 24px;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.pages .p_staff .staff_wrap .staff_card dl dd {
    font-size: 15px;
    letter-spacing: 0.1em;
    padding-bottom: 7px;
}

.pages .p_staff .staff_wrap .staff_card .card_txt {
    font-size: 15px;
    line-height: 2.2;
    text-align: justify;
}

.staff-details .p_staff #content {
    padding: 0 0 0;
}

.pages .p_staff .staff_section {
    background-color: #e4f7f9;
    padding: 83px 0 94px;
}

.pages .p_staff .details_wrap {
    width: 94%;
    max-width: 1200px;
    background-color: var(--white-color);
    border-radius: 20px;
    padding: 100px 0 98px;
    margin: 0 auto;
}

.pages .p_staff .details_wrap .inner {
    max-width: 1000px;
}

.pages .p_staff .media_headline {
    display: flex;
    justify-content: space-between;
    gap: 40px;
    margin-bottom: 90px;
}

.pages .p_staff .media_headline figure {
    width: 46.875vw;
    max-width: 480px;
    height: 29.59vw;
    max-height: 303px;
    border-radius: 10px;
    overflow: hidden;
}

.pages .p_staff .media_headline figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pages .p_staff .media_headline .media_meta {
    width: 100%;
    display: block;
    padding-top: 26px;
    margin-bottom: 0;
    flex: 1;
}

.pages .p_staff .media_meta .media_title {
    font-size: 32px;
    margin-bottom: 14px;
}

.pages .p_staff .media_meta .staff_exp {
    font-size: 16px;
    color: var(--blue-color);
    margin-bottom: 21px;
}

.pages .p_staff .media_meta .staff_des {
    font-size: 16px;
    line-height: 2.5;
}

.pages .p_staff .details_wrap .contents_detail {
    margin-bottom: 86px;
}

.pages .p_staff .details_wrap .contents_detail dl:not(:last-child) {
    margin-bottom: 38px;
}

.pages .p_staff .details_wrap .contents_detail dl dt {
    font-size: 24px;
    font-weight: 500;
    line-height: 1.75;
    color: var(--blue-color);
    margin-bottom: 18px;
}

.pages .p_staff .details_wrap .contents_detail dl dd {
    line-height: 2.5;
}

.pages .p_staff .details_wrap .btn_primary {
    margin-bottom: 80px;
}

.pages .p_staff .media_back {
    display: flex;
}

.pages .p_staff .media_back li {
    width: 50%;
    height: 120px;
}

.pages .p_staff .media_back li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    border: 2px solid var(--blue-color);
    padding: 0 28px;
}

.pages .p_staff .media_back li a .nav_title {
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 1;
}

.pages .p_staff .media_back li a .icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--blue-color);
    border: 2px solid var(--blue-color);
    margin-left: 28px;
    position: relative;
    overflow: hidden;
    transition: all .3s ease;
    flex-shrink: 0;
}

.pages .p_staff .media_back li a .icon::before,
.pages .p_staff .media_back li a .icon::after {
    position: absolute;
    content: '';
    background-image: url(../images/common/icon_arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 19px;
    height: 12px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all .3s ease;
}

.pages .p_staff .media_back li a .icon::after {
    transform: translate(-70%, -50%);
    opacity: 0;
}

.pages .p_staff .media_back li:first-child a {
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
}

.pages .p_staff .media_back li:first-child a .icon {
    margin-right: 28px;
    margin-left: 0;
    transform: rotate(-180deg);
}

.pages .p_staff .media_back li:last-child a {
    width: calc(100% + 2px);
    justify-content: flex-end;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
    margin-left: -2px;
}

/* ------------------------------------------------------
p_about
------------------------------------------------------ */
#about #wrapper {
    overflow: inherit;
}

.pages .p_about #p_mainvisual h2 i {
    background-image: url(../images/top/idx_recruit_decor01.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 133px;
    height: 214px;
    position: absolute;
    top: 45px;
    right: -90px;
    z-index: 1;
    pointer-events: none;
}

.pages #about_info {
    position: relative;
}

.pages #about_info .about_info_gallery {
    position: sticky;
    top: 0;
    height: 100vh;
    pointer-events: none;
    overflow: hidden;
}

.pages #about_info .about_info_gallery .gallery_item {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.pages #about_info .about_info_gallery .gallery_item:not(.image01)::before {
    position: absolute;
    content: '';
    background: rgba(0, 0, 0, 0.5);
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
}

.pages #about_info .about_info_gallery .gallery_item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pages #about_info .about_info_gallery .image01 {
    opacity: 1;
    z-index: 1;
}

.pages #about_info .about_info_gallery .image01 figure {
    width: 65vh;
    height: 65vh;
    border-radius: 46px;
    overflow: hidden;
    position: absolute;
    top: 50%;
    right: 13.333vw;
    transform: translateY(-50%);
    will-change: width, height, top, left, transform, border-radius;
}

.pages #about_info .about_info_gallery .image02 {
    z-index: 2;
}

.pages #about_info .about_info_gallery .image03 {
    z-index: 3;
}

.pages #about_info .info_card {
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.pages #about_info .info_card:not(#card01) {
    color: var(--white-color);
}

.pages #about_info .info_card .main_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 34px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.94;
}

.pages #about_info .info_card .info_card_txt {
    font-size: 22px;
    font-weight: 500;
    line-height: 2.72;
    text-align: justify;
}

.pages #about_info .info_card .info_card_txt p:not(:last-child) {
    margin-bottom: 61px;
}

.pages #about_info .info_card .sub_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 34px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    margin-bottom: 64px;
}

.pages #about_info .info_card .info_card_frame {
    border: 1px solid var(--white-color);
    border-radius: 16px;
    padding: 74px 46px;
}

.pages #about_info .info_card .info_card_frame ul {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}

.pages #about_info .info_card .info_card_frame ul li {
    width: calc((100% - 30px) / 2);
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    padding-left: 15px;
    position: relative;
}

.pages #about_info .info_card .info_card_frame ul li::before {
    position: absolute;
    content: '';
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: currentColor;
    top: 13px;
    left: 0;
}

.pages #about_info #card01 {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.pages #about_info #card01 .inner {
    max-width: 1300px;
}

.pages #about_info #card02,
.pages #about_info #card03 {
    padding-top: 30vh;
    padding-bottom: 30vh;
}

.pages #about_info #card02 .inner {
    max-width: 850px;
}

.pages #our_strength {
    background: var(--blue-color);
    padding: 100px 0 150px;
    overflow: hidden;
}

.pages #our_strength .under_title {
    color: var(--white-color);
    margin-bottom: 59px;
}

.pages #our_strength .strength_card {
    padding: 76px 0 71px;
    margin-bottom: 50px;
    position: relative;
    z-index: 1;
}

.pages #our_strength .strength_card::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: var(--white-color);
    top: 0;
    z-index: -1;
    opacity: 0;
}

.pages #our_strength .strength_card:nth-child(odd)::before {
    border-top-left-radius: 30px;
    border-bottom-left-radius: 30px;
    left: 100px;
}

.pages #our_strength .strength_card:nth-child(even)::before {
    border-top-right-radius: 30px;
    border-bottom-right-radius: 30px;
    right: 100px;
}

.pages #our_strength .strength_card:last-child {
    margin-bottom: 0;
}

.pages #our_strength .strength_card .inner {
    width: 76.667vw;
    max-width: 1150px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 35px;
    opacity: 0;
    transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.pages #our_strength .strength_card .strength_component {
    width: 46.667vw;
    max-width: 700px;
}

.pages #our_strength .strength_card .strength_tag {
    font-family: var(--ZenMaruGothic-font);
    font-weight: 500;
    margin-bottom: 29px;
}

.pages #our_strength .strength_card .strength_tag span {
    display: inline-block;
    letter-spacing: 0.1em;
    color: var(--white-color);
    background: var(--blue-color);
    border-radius: 6px;
    padding: 4px 10px 5px 11px;
}

.pages #our_strength .strength_card .strength_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 36px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    text-align: justify;
    margin-bottom: 25px;
}

.pages #our_strength .strength_card .strength_txt {
    line-height: 2.5;
    text-align: justify;
}

.pages #our_strength .strength_card.is-animated:nth-child(odd)::before {
    animation: slideInrl 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

.pages #our_strength .strength_card.is-animated:nth-child(even)::before {
    animation: slideInlr 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes slideInrl {
    0% {
        transform: translateX(200px);
        opacity: 0;
    }

    100% {
        transform: translateX(0);
    }

    40%,
    100% {
        opacity: 1;
    }
}

@keyframes slideInlr {
    0% {
        transform: translateX(-200px);
        opacity: 0;
    }

    100% {
        transform: translateX(0);
    }

    40%,
    100% {
        opacity: 1;
    }
}

.pages #our_strength .strength_card.is-animated .inner {
    opacity: 1;
    transition-delay: .5s;
}

.pages #about_profile {
    background: #e4f7f9;
    padding: 100px 0 150px;
    position: relative;
}

.pages #about_profile .inner {
    max-width: 1000px;
}

.pages #about_profile .under_title {
    margin-bottom: 58px;
}

.pages #about_profile .tb_profile {
    background: var(--white-color);
}

.pages #about_profile .about_decor03 {
    width: 20.667vw;
    max-width: 217px;
    height: 20vw;
    max-height: 210px;
    top: 0;
    left: 10%;
    bottom: auto;
    right: auto;
}

.pages #about_greeting {
    padding: 100px 0 100px;
    overflow: hidden;
}

.pages #about_greeting .under_title {
    margin-bottom: 73px;
}

.pages #about_greeting .greeting_wrap {
    display: flex;
    justify-content: space-between;
    gap: 35px;
}

.pages #about_greeting .greeting_profile {
    width: 100%;
    max-width: 560px;
}

.pages #about_greeting .greeting_profile figure {
    width: 100%;
    height: 45.566vw;
    max-height: 560px;
    border-radius: 40px;
    margin-bottom: 19px;
    overflow: hidden;
}

.pages #about_greeting .greeting_profile figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pages #about_greeting .greeting_profile .greeting_title {
    font-size: 22px;
    font-weight: 500;
    line-height: 1.82;
}

.pages #about_greeting .greeting_txt {
    width: 100%;
    max-width: 560px;
    line-height: 2.5;
    text-align: justify;
}

#about #footer .box_contact {
    padding-top: 132px;
    overflow: hidden;
}

#about #footer .footer_connect::before {
    width: 100%;
}

/* ------------------------------------------------------
p_recruit
------------------------------------------------------ */
.pages .p_recruit #p_mainvisual h2 i {
    background-image: url(../images/top/idx_recruit_decor02.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 260px;
    height: 199px;
    position: absolute;
    top: 30px;
    right: -130px;
    z-index: 1;
    pointer-events: none;
}

.pages .p_recruit #content {
    padding-top: 129px;
}

.pages #recruit_info {
    background: #e4f7f9;
    padding: 136px 0 151px;
    position: relative;
    z-index: 1;
}

.pages #recruit_info::before {
    position: absolute;
    content: '';
    background-image: url(../images/recruit/recruit_shape02.png);
    background-repeat: repeat-y;
    background-size: contain;
    width: 1774px;
    height: 100%;
    top: 130px;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
}

.pages #recruit_info .recruit_info_title {
    font-size: 34px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-align: center;
    margin-bottom: 50px;
    position: relative;
    z-index: 1;
}

.pages #recruit_info .info_headline {
    padding: 117px 0 0;
    margin-bottom: 149px;
    position: relative;
    z-index: 1;
}

.pages #recruit_info .info_headline .info_headline_txt {
    width: 100%;
    max-width: 480px;
    line-height: 2.5;
    color: var(--white-color);
    text-align: justify;
    padding: 117px 90px;
    margin-left: auto;
    box-sizing: content-box;
    position: relative;
    z-index: 1;
}

.pages #recruit_info .info_headline .info_headline_txt::before {
    position: absolute;
    content: '';
    background-image: url(../images/recruit/recruit_info_shape.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width: 100%;
    height: 100%;
    top: 45%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}

.pages #recruit_info .info_headline .info_headline_image {
    width: 76vw;
    max-width: 950px;
    height: 64.56vw;
    max-height: 807px;
    position: absolute;
    top: 0;
    left: -30px;
    z-index: -1;
}

.pages #recruit_info .info_headline .info_headline_image .img01 {
    -webkit-clip-path: url(#mvmask);
    clip-path: url(#mvmask);
    background-image: url(../images/recruit/recruit_info_img01.jpg);
    background-repeat: no-repeat;
    background-position: center right;
    background-size: cover;
    width: 100%;
    height: 100%;
    position: relative;
}

.pages #recruit_info .svg_clip {
    position: absolute;
    top: 0;
    left: 0;
}

.pages #recruit_info .recruit_info_item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 45px;
    margin-bottom: 19px;
}

.pages #recruit_info .recruit_info_item .item_component {
    width: 100%;
    max-width: 530px;
    flex: 1;
}

.pages #recruit_info .recruit_info_item h4 {
    font-size: 38px;
    font-weight: 400;
    letter-spacing: 0.1em;
    line-height: 2.05;
    color: var(--blue-color);
    display: inline;
    background: var(--white-color);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    border-radius: 4px;
    padding: 1px 12px 4px 17px;
}

.pages #recruit_info .recruit_info_item .item_txt {
    line-height: 2.5;
    text-align: justify;
    margin-top: 25px;
}

.pages #recruit_info .recruit_info_item .item_image {
    width: 48vw;
    max-width: 600px;
    height: 48vw;
    max-height: 600px;
    border-radius: 50%;
    position: relative;
    z-index: 1;
}

.pages #recruit_info .recruit_info_item .item_image::before {
    position: absolute;
    content: '';
    background: url(../images/recruit/recruit_info_item.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 100%;
    height: 100%;
    top: 30px;
    left: 30px;
    z-index: -1;
}

.pages #recruit_info .recruit_info_item .item_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.pages #recruit_info .recruit_info_item:nth-child(even) {
    flex-direction: row-reverse;
}

.pages #recruit_numbers {
    background: var(--blue-color);
    padding: 100px 0 140px;
    position: relative;
    z-index: 1;
}

.pages #recruit_numbers .under_title {
    color: var(--white-color);
    margin-bottom: 79px;
}

.pages #recruit_numbers .recruit_numbers_list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.pages #recruit_numbers .recruit_numbers_list li {
    width: calc((100% - 40px) / 3);
    min-height: 250px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: var(--white-color);
    border-radius: 20px;
    padding: 0 10px 10px;
    margin-bottom: 20px;
    overflow: hidden;
}

.pages #recruit_numbers .recruit_numbers_list li h4 {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: #fbb03b;
    padding-bottom: 5px;
    margin-bottom: 15px;
    position: relative;
}

.pages #recruit_numbers .recruit_numbers_list li h4::after {
    position: absolute;
    content: '';
    width: 36px;
    height: 3px;
    background-color: currentColor;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
}

.pages #recruit_numbers .recruit_numbers_list li .record_no {
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1;
    margin-bottom: 22px;
}

.pages #recruit_numbers .recruit_numbers_list li .record_no span {
    font-size: 321.43%;
    letter-spacing: 0;
    color: var(--blue-color);
    margin-right: 12px;
}

.pages #recruit_numbers .recruit_numbers_list li .record_note {
    font-weight: 500;
}

.pages #recruit_numbers .about_decor03 {
    width: 20.19vw;
    max-width: 212px;
    height: 20.19vw;
    max-height: 212px;
    top: -90px;
    right: 10%;
    bottom: auto;
}

.pages #recruit_interview {
    background: #e4f7f9;
    padding: 100px 0 160px;
}

.pages #recruit_interview .under_title {
    margin-bottom: 79px;
}

.pages #recruit_interview .interview_list {
    display: flex;
    flex-wrap: wrap;
    gap: 42px;
}

.pages #recruit_interview .interview_list .interview_card {
    width: calc((100% - 84px) / 3);
}

.pages #recruit_interview .interview_list .interview_card a {
    width: 100%;
    display: block;
    color: var(--white-color);
    background: var(--blue-color);
    border-radius: 20px;
    overflow: hidden;
}

.pages #recruit_interview .interview_list .interview_card figure {
    height: 18.794vw;
    max-height: 240px;
    overflow: hidden;
}

.pages #recruit_interview .interview_list .interview_card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.pages #recruit_interview .interview_card .interview_component {
    padding: 13px 25px 25px;
}

.pages #recruit_interview .interview_card .interview_component h4 {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.89;
    border-bottom: 1px solid var(--white-color);
    padding-bottom: 17px;
    margin-bottom: 16px;
}

.pages #recruit_interview .interview_card .interview_component .staff_info,
.pages #recruit_interview .interview_card .interview_component .month_join {
    font-size: 15px;
    font-weight: 500;
}

.pages #recruit_interview .interview_card .interview_component .staff_info {
    margin-bottom: 5px;
}

.interview-details .p_staff #content {
    padding: 0 0 0;
}

.interview-details .p_staff .media_headline {
    align-items: center;
}

.interview-details .p_staff .media_headline .media_meta {
    padding-top: 0;
}

.interview-details .main_copy {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.71;
    color: var(--blue-color);
    margin-bottom: 25px;
}

.interview-details .staff_info,
.interview-details .month_join {
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.interview-details .staff_info {
    margin-bottom: 6px;
}

.interview-details #footer .box_contact {
    background: #e4f7f9;
}

.interview-details #footer .box_contact .inner {
    z-index: 1;
}

.pages #recruit_requirements {
    padding: 100px 0 98px;
}

.pages #recruit_requirements .inner {
    max-width: 1000px;
}

.pages #recruit_requirements .under_title {
    margin-bottom: 30px;
}

.pages #recruit_requirements .recruit_requirements_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 65px;
}

.pages #recruit_requirements .recruit_requirements_list {
    margin-bottom: 72px;
}

.pages #recruit_requirements .tb_requirements {
    border-top: 3px solid var(--blue-color);
    border-bottom: 3px solid var(--blue-color);
    margin-bottom: 75px;
}

.pages #recruit_requirements .tb_requirements th,
.pages #recruit_requirements .tb_requirements td {
    padding: 32px 10px 31px 20px;
}

.pages #recruit_requirements .tb_requirements tr:first-child th,
.pages #recruit_requirements .tb_requirements tr:first-child td {
    border-top: 0;
}

.pages #recruit_requirements .tb_requirements tr:last-child th,
.pages #recruit_requirements .tb_requirements tr:last-child td {
    border-bottom: 0;
}

.pages #recruit_requirements .tb_requirements th {
    width: 21%;
    color: var(--blue-color);
    background: none;
    border-bottom-color: #b3b3b3;
}

.pages #recruit_requirements .tb_requirements td {
    border-right: 0;
}

.pages #recruit_requirements .btn_primary {
    text-align: center;
}

.pages #recruit_requirements .not_hiring {
    text-align: center;
}

.pages #recruit_requirements .not_hiring_title {
    font-size: 38px;
    font-weight: 400;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-bottom: 17px;
}

.pages #recruit_requirements .not_hiring_txt {
    line-height: 2.5;
    margin-bottom: 65px;
}

.pages #recruit_requirements .now_hiring.is-hide {
    display: none;
}

.pages #recruit_requirements .not_hiring.is-hide {
    display: none;
}

/* ------------------------------------------------------
p_case
------------------------------------------------------ */
.pages .p_case #p_mainvisual h2 i {
    background-image: url(../images/top/idx_case_decor1.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 211px;
    height: 183px;
    position: absolute;
    top: 45px;
    right: -130px;
    z-index: 1;
    pointer-events: none;
}

.pages .p_case #content {
    padding-top: 122px;
}

.pages #case_info {
    background: #e4f7f9;
    padding: 80px 0;
    position: relative;
}

.pages #case_info .inner {
    max-width: 1000px;
}

.pages #case_info .case_info_txt {
    line-height: 2.5;
    text-align: center;
    margin-bottom: 108px;
}

.pages #case_info .case_list {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
}

.pages #case_info .case_list .case_item {
    width: calc((100% - 40px) / 2);
    margin-bottom: 23px;
}

.pages #case_info .case_item .case_image {
    width: 100%;
    height: 30.639vw;
    max-height: 326px;
    margin-bottom: 20px;
    position: relative;
    z-index: 1;
}

.pages #case_info .case_item .case_image::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: var(--blue-color);
    top: 4px;
    left: 4px;
    z-index: -1;
}

.pages #case_info .case_item .case_image a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    color: var(--white-color);
    background: var(--white-color);
    padding: 10px 10px;
    position: relative;
    z-index: 1;
}

.pages #case_info .case_item .case_image a::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(15, 110, 114, 0.5);
    top: 0;
    left: 0;
    opacity: 0;
    transition: opacity .6s ease;
    pointer-events: none;
}

.pages #case_info .case_item .case_image .case_link_txt {
    width: 94%;
    font-size: 24px;
    line-height: 1.75;
    text-align: center;
    margin-bottom: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    transition: all .6s ease;
}

.pages #case_info .case_item .case_image figure {
    width: 100%;
    height: 100%;
    background: #f2f2f2;
    overflow: hidden;
}

.pages #case_info .case_item .case_image figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pages #case_info .case_item .case_tag {
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--blue-color);
    margin-bottom: 4px;
}

.pages #case_info .case_item .case_title {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--blue-color);
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 1;
}

.pages .p_case .wp-pagenavi {
    margin-top: 38px;
}

#case #footer .box_contact {
    background: #e4f7f9;
}

#case #footer .box_contact .inner {
    z-index: 1;
}

.case-details .p_case #content {
    padding: 0 0 0;
}

.pages .p_case .media_wrap {
    width: 100%;
    max-width: 100%;
    background-color: #e4f7f9;
    padding: 117px 0 94px;
}

.pages .p_case .media_wrap .details_wrap {
    width: 94%;
    max-width: 1000px;
    margin: 0 auto;
    flex: inherit;
}

.pages .details_wrap .main_photo img {
    border-radius: 20px;
}

.pages .p_case .contents_detail p {
    line-height: 2.5;
}

.pages .p_case .contents_detail h3,
.pages .p_case .contents_detail h4,
.pages .p_case .contents_detail h5,
.pages .p_case .contents_detail h6 {
    line-height: 1.75;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
}

.pages .p_case .contents_detail h4 {
    font-size: 20px;
    font-weight: 600;
    color: #fbb03b;
}

.pages .p_case .contents_detail .wp-block-columns:not(:last-child) {
    margin-bottom: 38px;
}

.pages .p_case .contents_detail .wp-block-image img {
    border-radius: 10px;
}

.pages .p_case .contents_detail .wp-block-image {
    margin-bottom: 13px;
}

.pages .p_case .details_wrap .btn_primary {
    margin-bottom: 80px;
}

.pages .p_case .media_back {
    display: flex;
}

.pages .p_case .media_back li {
    width: 50%;
    height: 120px;
}

.pages .p_case .media_back li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    background: var(--white-color);
    border: 2px solid var(--blue-color);
    padding: 0 28px;
}

.pages .p_case .media_back li a .nav_title {
    text-align: justify;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 1;
}

.pages .p_case .media_back li a .icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--blue-color);
    border: 2px solid var(--blue-color);
    margin-left: 28px;
    position: relative;
    overflow: hidden;
    transition: all .3s ease;
    flex-shrink: 0;
}

.pages .p_case .media_back li a .icon::before,
.pages .p_case .media_back li a .icon::after {
    position: absolute;
    content: '';
    background-image: url(../images/common/icon_arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 19px;
    height: 12px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all .3s ease;
}

.pages .p_case .media_back li a .icon::after {
    transform: translate(-70%, -50%);
    opacity: 0;
}

.pages .p_case .media_back li:first-child a {
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
}

.pages .p_case .media_back li:first-child a .icon {
    margin-right: 28px;
    margin-left: 0;
    transform: rotate(-180deg);
}

.pages .p_case .media_back li:last-child a {
    width: calc(100% + 2px);
    justify-content: flex-end;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
    margin-left: -2px;
}

/* ------------------------------------------------------
p_service
------------------------------------------------------ */
#service #wrapper {
    overflow: inherit;
}

.pages .p_service #p_mainvisual h2 i {
    background-image: url(../images/top/idx_service_decor01.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 236px;
    height: 168px;
    position: absolute;
    top: 45px;
    right: -125px;
    z-index: 1;
    pointer-events: none;
}

.pages .p_service #content {
    padding-top: 122px;
}

.pages #service_intro {
    background: #e4f7f9;
    padding: 118px 0 155px;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.pages #service_intro::before {
    position: absolute;
    content: '';
    background-image: url(../images/service/service_shape02.png);
    background-repeat: repeat-y;
    background-size: contain;
    width: 1774px;
    height: 100%;
    top: 18%;
    left: 55%;
    transform: translateX(-50%);
    z-index: -1;
}

.pages #service_intro .service_intro_wrap {
    display: flex;
    margin-bottom: 121px;
    position: relative;
}

.pages #service_intro .service_intro_photo {
    width: 66.667vw;
    height: 51.852vw;
    max-height: 700px;
    margin-left: -23.333vw;
    position: relative;
}

.pages #service_intro .service_intro_photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-top-left-radius: 40px;
    border-bottom-left-radius: 40px;
}

.pages #service_intro .service_intro_photo .about_decor03 {
    width: 20.762vw;
    max-width: 218px;
    height: 22.19vw;
    max-height: 233px;
    bottom: -190px;
    right: 100px;
}

.pages #service_intro .service_intro_component {
    width: 56.667vw;
    padding: 41px 0 0 150px;
    position: relative;
    z-index: 1;
}

.pages #service_intro .service_intro_title {
    font-size: 48px;
    line-height: 1.83;
    color: var(--blue-color);
    display: inline;
    background: var(--white-color);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    border-radius: 4px;
    padding: 0 12px 0 17px;
}

.pages #service_intro .service_intro_frame {
    padding: 87px 100px 88px 0;
    margin-top: 39px;
    position: relative;
}

.pages #service_intro .service_intro_frame::before {
    position: absolute;
    content: '';
    background: var(--blue-color);
    width: 100vw;
    height: 100%;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
    top: 0;
    right: 0;
    z-index: -1;
}

.pages #service_intro .service_intro_txt {
    line-height: 2.5;
    text-align: justify;
    color: var(--white-color);
}

.pages #service_intro .service_intro_txt p:not(:last-child) {
    margin-bottom: 40px;
}

.pages #service_intro .about_decor03 {
    right: -80%;
}

.pages #service_intro .service_intro_list {
    width: 94%;
    max-width: 1200px;
    margin: 0 auto 187px;
}

.pages #service_intro .service_info_item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 45px;
    margin-bottom: 19px;
}

.pages #service_intro .service_info_item .item_component {
    width: 100%;
    max-width: 530px;
    flex: 1;
}

.pages #service_intro .service_info_item h4 {
    font-size: 38px;
    font-weight: 400;
    letter-spacing: 0.1em;
    line-height: 2.05;
    color: var(--blue-color);
    display: inline;
    background: var(--white-color);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    border-radius: 4px;
    padding: 1px 12px 4px 17px;
}

.pages #service_intro .service_info_item .item_txt {
    line-height: 2.5;
    text-align: justify;
    margin-top: 25px;
}

.pages #service_intro .service_info_item .item_image {
    width: 48vw;
    max-width: 600px;
    height: 48vw;
    max-height: 600px;
    border-radius: 50%;
    position: relative;
    z-index: 1;
}

.pages #service_intro .service_info_item .item_image::before {
    position: absolute;
    content: '';
    background: url(../images/service/service_intro_item.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 100%;
    height: 100%;
    top: 30px;
    left: 30px;
    z-index: -1;
}

.pages #service_intro .service_info_item .item_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.pages #service_intro .service_info_item:nth-child(even) {
    flex-direction: row-reverse;
}

.pages #service_intro .service_area {
    width: 94%;
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
    gap: 35px;
    background: var(--white-color);
    border-radius: 20px;
    border: 2px solid var(--blue-color);
    padding: 65px 100px 75px;
    margin: 0 auto;
}

.pages #service_intro .service_area .service_area_txt {
    width: 100%;
    max-width: 500px;
    line-height: 2.5;
    padding-top: 21px;
    flex: 1;
}

.pages #service_intro .service_area .service_area_txt p:not(:last-child) {
    margin-bottom: 40px;
}

.pages #service_intro .service_area .under_title {
    text-align: left;
    margin-bottom: 7px;
}

.pages #service_flow {
    background: var(--blue-color);
    padding: 114px 0 180px;
    position: relative;
    z-index: 2;
    overflow: hidden;
}

.pages #service_flow .inner {
    max-width: 1000px;
}

.pages #service_flow h3.under_title {
    color: var(--white-color);
    margin-bottom: 63px;
}

.pages #service_flow .service_flow_list dl {
    width: 100%;
    min-height: 180px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    background: var(--white-color);
    counter-increment: num;
    border-radius: 20px;
    padding: 30px 30px;
    margin-bottom: 40px;
}

.pages #service_flow .service_flow_list dl:last-child {
    margin-bottom: 0;
}

.pages #service_flow .service_flow_list dl dt {
    width: 100%;
    max-width: 350px;
    display: flex;
    align-items: center;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    padding-bottom: 8px;
}

.pages #service_flow .service_flow_list dl dt span {
    width: 70px;
    height: 70px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: var(--blue-color);
    padding: 0 0 6px 2px;
    margin-right: 20px;
    position: relative;
    top: 2px;
    flex-shrink: 0;
}

.pages #service_flow .service_flow_list dl dt span::before {
    content: counter(num, decimal-leading-zero);
    font-size: 32px;
    letter-spacing: 0.1em;
    color: var(--white-color);
}

.pages #service_flow .service_flow_list dl dd {
    width: 100%;
    max-width: 560px;
    letter-spacing: 0.1em;
    line-height: 2.5;
    text-align: justify;
    flex: 1;
}

.pages #service_flan .service_flan_cover {
    width: 100%;
    height: 100vh;
    position: sticky;
    top: 120px;
    left: 0;
}

.pages #service_flan .service_flan_cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}

.pages #service_flan .service_flan_cover::before {
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    top: 0;
    left: 0;
}

.pages #service_flan .inner {
    max-width: 850px;
}

.pages #service_flan .service_flan_title {
    font-size: 34px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.94;
    text-align: center;
    color: var(--white-color);
    margin-bottom: 70px;
}

.pages #service_flan .service_flan_txt {
    font-size: 22px;
    font-weight: 500;
    line-height: 2.72;
    color: var(--white-color);
    text-align: justify;
    padding-bottom: 152px;
}

.pages #service_flan .service_flan_txt p:not(:last-child) {
    margin-bottom: 61px;
}

.pages #service_qa {
    background: #e4f7f9;
    padding-top: 113px;
    overflow: hidden;
}

.pages #service_qa .under_title {
    margin-bottom: 71px;
}

.pages #service_qa .service_qa_list .l-tab-btns {
    width: 100%;
    display: flex;
    border-bottom: 2px solid var(--blue-color);
}

.pages #service_qa .service_qa_list .l-tab-btns li {
    width: 50%;
    height: 70px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    text-align: center;
    background: var(--white-color);
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    padding: 0 10px;
}

.pages #service_qa .service_qa_list .l-tab-btns li:not(.is-active) {
    cursor: pointer;
}

.pages #service_qa .service_qa_list .l-tab-btns li.is-active {
    color: var(--white-color);
    background: var(--blue-color);
}

.pages #service_qa .service_qa_list .tab-box-list {
    background: var(--white-color);
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    padding: 21px 0 60px;
}

.pages #service_qa .service_qa_list .tab-box {
    width: 94%;
    max-width: 1000px;
    margin: 0 auto;
}

.pages #service_qa .service_qa_list dl {
    width: 100%;
    border-bottom: 1px solid #b3b3b3;
    padding: 34px 0 28px;
}

.pages #service_qa .service_qa_list dl dt {
    font-size: 18px;
    color: var(--blue-color);
    letter-spacing: 0.1em;
    margin-bottom: 13px;
}

.pages #service_qa .service_qa_list dl dd {
    line-height: 2.5;
}

.pages #service_qa .service_qa_list .is-hidden {
    display: none;
}

#service #footer .box_contact {
    background: #e4f7f9;
    padding-top: 160px;
    overflow: hidden;
}

#service #footer .box_contact .inner {
    z-index: 1;
}

#service #footer .footer_connect::before {
    width: 100%;
}

/* ------------------------------------------------------
p_notfound
------------------------------------------------------ */
#notfound #main {
    padding-top: 0;
}

.pages #notfound_info {
    width: 100%;
    height: 100vh;
    display: flex;
    align-items: center;
    text-align: center;
    background: #e4f7f9;
}

.pages #notfound_info .notfound_info_title {
    font-family: var(--ZenMaruGothic-font);
    font-size: 120px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-bottom: 41px;
}

.pages #notfound_info .notfound_info_subtitle {
    font-family: var(--ZenMaruGothic-font);
    font-size: 38px;
    font-weight: 400;
    letter-spacing: 0.1em;
    color: var(--blue-color);
    margin-bottom: 42px;
}

.pages #notfound_info .notfound_info_txt {
    line-height: 2.5;
    margin-bottom: 54px;
}

/* MOZZILLA CSS */
@-moz-document url-prefix() {}

/* IE CSS */
@media screen\0 {}

/* EDGE 12+ CSS */
@supports (-ms-ime-align:auto) {}
