html {
    font-size: 62.5%;
}

body {
    font-family: "Noto Sans JP", sans-serif;
    padding-top: 0 !important;
    color: #373E42;
    line-height: 2.0;
    font-size: 1.6rem;
}

h3 {
    margin: 0 0 32px 0;
    font-size: 2.4rem;
    font-weight: bold;
}

.u-none {
    display: none;
}

.u-block {
    display: block;
}

.p-header,
.p-m_navigation {
    background-color: rgb(255 255 255 / 18%);
}

.p-header__nav-heading img {
    width: 110px;
}

.m_navigationMenu {
    margin-right: 130px;
}

.m_navigationMenu li {
    margin: 0 32px 0 0;
}

.m_navigationMenu li a {
    font-size: 1.4rem;
    font-weight: bold;
}

.m_navigationMenu li:last-child a,
.roundBtn_wrapper a {
    display: inline-block;
    padding: 8px 24px;
    border-radius: 24px;
    background-color: #14C3DC;
    color: #fff;
    font-weight: bold;
}

.roundBtn_wrapper {
    text-align: right;
}

.roundBtn_wrapper a:hover {
    text-decoration: underline;
}

.m_navigationMenu li:nth-child(3) a:after {
    display: inline-block;
    content: "";
    margin: 0 0 -2px 4px;
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60e55538f37b1/original.png);
    background-size: contain;
    width: 14px;
    height: 14px;
}

.m_navigationMenu li:last-child a:after,
.roundBtn_wrapper a:after {
    display: inline-block;
    content: "";
    margin: 0 0 -2px 4px;
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60e5565c5fcb7/original.png);
    background-size: contain;
    width: 14px;
    height: 14px;
}
/* KV */
.main_area .content_wrapper {
    position: relative;
    height: 960px;
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/f1fa6aa0-3a1a-013e-5ef7-0a58a9feac02/w1920.png);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.main_area .content_inner {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%; /* 例: 親要素(.content_wrapper)の80%の幅にする */
    max-width: 580px; /* 例: 最大幅を設定して、大きくなりすぎないようにする */
}

.main_area .content_inner .vision_text_img {
    position: relative;
    width: 50%;
    left: -20px;
}

.main_area .content_inner .vision_text_img img {
    display: block;
    margin: 0 auto;
    width: 100%;
    height: auto;
}

.main_area .content_inner .txt_wrapper {
    text-align: left;
    color: #fff;
}

.main_area .content_inner h1 {
    margin-bottom: 16px;
    font-size: 48px;
    font-weight: bold;
    line-height: 150%;
}

.main_area .content_inner p {
    font-size: 22px;
    line-height: 150%;
}

.container_wrapper {
    margin: 200px 0;
}

.container_wrapper .sectionTitle_wrapper {
    position: relative;
    height: 220px;
    font-size: 3.2rem;
    text-align: center;
    margin: 0 0 80px 0;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.container_wrapper .service_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810b4ec4/original.png);
}

.container_wrapper .recruit_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810b6322/original.png);
}

.container_wrapper .vision_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/83909dc0-27cb-013e-d775-0a58a9feac02/vision-title.png);
}

.container_wrapper .aboutus_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810badff/original.png);
}

.container_wrapper .board_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810b83af/original.png);
}

.container_wrapper .overview_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810be46d/original.png);
}

.container_wrapper .history_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ec0810b70e3/original.png);
}

.container_wrapper .investor_title {
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/60ee3ea71a70f/original.png);
}

.container_wrapper .sectionTitle_wrapper h2 {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

.container_wrapper .content_wrapper--middle {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px;
}

.container_wrapper .content_wrapper--small {
    max-width: 980px;
    margin: 0 auto;
    padding: 0 20px;
}

.service_wrapper .content_inner {
    display: flex;
    flex-wrap: wrap;
}

.service_wrapper .content_parts {
    position: relative;
    width: calc(100% / 2 - 40px);
    margin: 0 40px 40px 0;
    border: solid 1px #EDEDED;
}

/* .service_wrapper .content_parts:last-of-type{
      margin: 0;
  } */
.service_wrapper .content_parts .txt_area {
    padding: 48px 48px 68px 48px;
    text-align: center;
}

.service_wrapper .content_parts .txt_area span,
.board_wrapper .introduction_parts .position {
    color: #14C3DC;
    font-weight: bold;
}

.board_wrapper .introduction_parts .position {
    border-bottom: solid 1px;
}

.service_wrapper .content_parts .txt_area p {
    text-align: left;
}

.btn_wrapper {
    text-align: right;
}

.service_wrapper .content_parts .btn_wrapper {
    position: absolute;
    right: 0;
    bottom: 0;
    margin: 40px 0 0 0;
}

.btn_wrapper a {
    display: inline-block;
    position: relative;
    text-decoration: none;
    cursor: pointer;
    width: 250px;
    padding: 6px 20px 12px;
    color: #fff;
    text-align: left;
    font-weight: bold;
    background-color: #14C3DC;
    transition: all .3s;
}

.btn_wrapper a:before {
    content: '';
    position: absolute;
    bottom: 10px;
    left: 5%;
    width: 88%;
    height: 1px;
    background: #fff;
    transition: all .3s;
}

.btn_wrapper a:after {
    content: '';
    position: absolute;
    bottom: 14px;
    right: 6%;
    width: 15px;
    height: 1px;
    background: #fff;
    transform: rotate(35deg);
    transition: all .3s;
}

.btn_wrapper a:hover {
    background-color: #69D4E3;
}

.btn_wrapper a:hover::before {
    left: 8%;
}

.btn_wrapper a:hover::after {
    right: 3%;
}

.btn_wrapper a img,
.footer-wrapper ul li a img {
    display: inline-block;
    margin: 0 0 2px 4px;
    width: 14px;
    height: 14px;
}

.recruit_wrapper .img_area {
    min-height: 560px;
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/d388bca0-5350-013e-ac0a-0a58a9feac02/corp_photo.png);
    background-size: cover;
    background-position: center;
}

.recruit_wrapper .txt_area .btn_wrapper {
    margin: 40px 0 0 0;
    text-align: right;
}

.recruit_wrapper .txt_area .btn_wrapper a {
    text-align: left;
}

.aboutus_wrapper .content_parts h1 {
    position: relative;
}

.aboutus_wrapper .content_parts h1:after {
    display: inline-block;
    content: "";
    position: absolute;
    right: 0;
    bottom: -20px;
    left: 0;
    width: 88px;
    height: 1px;
    background: #14C3DC;
    margin: 0 auto;
}

.aboutus_wrapper .content_parts .txt_area {
    margin: 52px 0 0 0;
}

.aboutus_list ul {
    margin: 80px 0;
    padding: 0;
    border-top: solid 1px #E0E0E0;
}

.aboutus_list ul li {
    display: flex;
    padding: 72px 16px 56px;
    list-style: none;
    border-bottom: solid 1px #E0E0E0;
}

.aboutus_list ul li h4 {
    position: relative;
    top: -12px;
    margin: 0 80px 0 0;
    font-size: 2.4rem;
    font-weight: bold;
}

.aboutus_list ul li h4 span {
    position: relative;
    top: -15px;
    margin-right: 4px;
    color: #14C3DC;
    font-size: 1.4rem;
    font-weight: bold;
}

.aboutus_list ul li .list_inner {
    flex: 1;
}

.aboutus_list ul li .list_inner div {
    margin: 0 0 72px 0;
}

.aboutus_list ul li .list_inner div:last-child {
    margin: 0;
}

.aboutus_list ul li .list_inner div h5 {
    margin-bottom: 16px;
    font-size: 1.6rem;
    font-weight: bold;
}

.board_wrapper .content_parts ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 80px 0;
    padding: 0;
}

.board_wrapper .content_parts .introduction_parts {
    list-style: none;
    margin: 0 100px 80px 0;
    width: calc(100% / 3 - 67px);
    text-align: center;
}

.board_wrapper .content_parts .introduction_parts:nth-of-type(3n) {
    margin-right: 0;
}

.board_wrapper .content_parts .introduction_parts img {
    margin: 0 0 16px;
}

.board_wrapper .content_parts .introduction_parts .position {
    display: block;
}

.board_wrapper .content_parts .introduction_parts .tag_wrapper {
    display: flex;
    justify-content: center;
}

.board_wrapper .content_parts .introduction_parts .tag_wrapper span {
    margin: 0 8px 0 0;
    padding: 4px 12px;
    min-width: 50px;
    font-size: 1.2rem;
    background-color: #F7F7F7;
    border-radius: 40px;
}

.board_wrapper .content_parts .introduction_parts .tag_wrapper span:last-child {
    margin: 0;
}

.board_wrapper .content_parts .introduction_parts h3 {
    margin: 12px 0;
}

.board_wrapper .content_parts .introduction_parts p {
    margin: 24px 0 0 0;
    text-align: left;
}

.overview_wrapper .content_parts dl {
    overflow: hidden;
}

.overview_wrapper .content_parts dl dt {
    float: left;
    clear: left;
    padding: 32px 16px;
    margin-right: 64px;
    width: 260px;
    border-bottom: solid 1px #E0E0E0;
}

.overview_wrapper .content_parts dl dd {
    float: left;
    padding: 32px 16px;
    width: calc(100% - 324px);
    border-bottom: solid 1px #E0E0E0;
}

.overview_wrapper .content_parts dl dt:first-of-type,
.overview_wrapper .content_parts dl dd:first-of-type {
    border-top: solid 1px #E0E0E0;
}

.overview_wrapper .content_parts dl dd.logo_dd {
    display: flex;
    align-items: flex-start;
    padding: 14px 16px;
}

.overview_wrapper .content_parts dl dd:last-child img {
    width: 156px;
}

.history_wrapper ul {
    margin: 120px 0 0 0;
    padding: 0;
}

.history_wrapper ul li {
    position: relative;
    width: calc(100% - 48px);
    margin: 40px 0 0 40px;
    padding: 20px 0 20px 40px;
    list-style: none;
    border-left: 1px solid #14C3DC;
}

.history_wrapper ul li h4 {
    position: absolute;
    top: -40px;
    left: -35px;
    padding: 0;
    font-size: 2.4rem;
    font-weight: bold;
}

.history_wrapper ul li h5 {
    float: left;
    margin: 0 80px 0 0;
    min-width: 40px;
    font-weight: bold;
    text-align: right;
}

.history_wrapper ul li p {
    display: flex;
    justify-content: flex-start;
    margin: 0 0 20px 0;
}

.history_wrapper ul li p:before {
    display: block;
    content: "ー";
    width: 14px;
    margin: 0 20px 0 0;
    color: #E0E0E0;
}

.container_wrapper .vision_wrapper {
    display: flex;
    gap: 40px;
}

.backgoundColor_area {
    margin-top: 200px;
    padding-bottom: 40px;
    background-color: #E7F9FA;
}

.serviceDetails_wrapper .img_wrapper {
    position: relative;
    top: -120px;
    width: 580px;
    margin: 0 auto -64px auto;
}

.serviceDetails_wrapper .img_wrapper img {
    width: 100%;
}

.serviceDetails_wrapper .txt_area .btn_wrapper {
    margin-top: 40px;
}

.serviceCatalog_wrapper {
    margin: 80px auto 0 auto !important;
}

.serviceCatalog_wrapper ul {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
}

.serviceCatalog_wrapper ul li {
    display: flex;
    flex-direction: column;
    width: calc(100% / 2 - 40px);
    margin: 0 80px 80px 0;
    padding: 40px 0 0 0;
    border-top: solid 4px #14C3DC;
    list-style: none;
}

.serviceCatalog_wrapper ul li:nth-of-type(2n) {
    margin: 0 0 80px 0;
}

.serviceCatalog_wrapper ul li p {
    margin-bottom: 40px;
}

.serviceCatalog_wrapper ul li .btn_wrapper {
    margin-top: auto;
}

.footer-wrapper {
    padding: 80px 0 0 0;
    background-color: #14c3dc;
}

.footer-wrapper .footer-inner {
    display: flex;
    justify-content: center;
    max-width: 700px;
    margin: 0 auto;
}

.footer-wrapper ul {
    display: flex;
    padding: 0;
}

.footer-wrapper ul li {
    margin: 0 20px 0 0;
    list-style: none;
}

.footer-wrapper ul li:last-of-type {
    margin-right: 0;
}

.footer-wrapper ul li a {
    color: #fff;
}

.s_footer-peraichi {
    background-color: #14c3dc;
}

.s_footer-peraichi .p-footer__inner {
    padding: 20px 0 80px 0;
    color: #fff;
}

.investor_wrapper .content_parts .img_wrapper {
    max-width: 350px;
    margin: 0 auto;
}

.investor_wrapper .content_parts,
.investor_wrapper .content_parts .btn_wrapper {
    text-align: center;
}

.isms img {
    width: 120px;
}

.isms span {
    display: block;
    color: #fff;
    font-size: 10px;
}

@media only screen and (min-width: 481px) and (max-width: 1024px) {
    .service_wrapper .content_inner {
        display: flex;
    }

    .service_wrapper .content_parts {
        margin: 0 20px 40px 0;
        width: calc(100% / 2 - 20px);
    }

    .service_wrapper .content_parts .txt_area {
        padding: 24px 18px 72px;
    }

    .overview_wrapper .content_parts dl dt {
        width: 160px;
        margin-right: 40px;
    }

    .overview_wrapper .content_parts dl dd {
        width: calc(100% - 200px);
    }

    .board_wrapper .content_parts .introduction_parts {
        margin: 0 40px 40px 0;
        width: calc(100% / 3 - 27px);
    }

    .aboutus_list ul li h4 {
        margin: 0 40px 0 0;
    }

    .serviceCatalog_wrapper ul li {
        width: calc(100% / 2 - 20px);
        margin: 0 40px 80px 0;
    }
}

/* global menu */
#section-5 .pera1-editable {
    position: fixed;
    right: 0;
    z-index: 10000;
    width: 170px;
}

.g-menu {
    position: absolute;
    right: 0;
    margin: 28px 40px 0;
    padding: 0;
}

.g-menu__item {
    position: relative;
    list-style: none;
}

.g-menu__link {
    display: flex;
    font-size: 14px;
    line-height: 1.5;
    color: #333;
    font-weight: bold;
}

.g-menu__link:before {
    display: block;
    position: relative;
    content: "";
    top: 3px;
    width: 14px;
    height: 14px;
    margin: 0 4px 0 0;
    background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/66c5ace09da97/original.png);
    background-size: contain;
}

.g-menu__dropdown-menu {
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 100%;
    right: 0;
    background: #f2f2f2;
    width: 200%;
    list-style: none;
    padding: 0;
}

.g-menu__dropdown-menu-item {
    border-bottom: 1px solid #ccc;
}

.g-menu__dropdown-menu-item:last-child {
    border-width: 0;
}

.g-menu__dropdown-menu-link {
    display: block;
    padding: 10px;
    font-size: 14px;
    line-height: 1.5;
    color: #333;
}

.g-menu__item:hover .g-menu__link {
    transition: .5s;
}

.g-menu__dropdown-menu-link:hover {
    opacity: .5;
}

.g-menu__item:hover .g-menu__dropdown-menu {
    opacity: 1;
    pointer-events: auto;
    transition: .5s;
}

@media only screen and (min-width: 1px) and (max-width: 480px) {
    #section-5 .pera1-editable {
        top: 0;
    }

    .g-menu {
        margin: 22px 50px 0;
    }
}


@media only screen and (min-width: 1px) and (max-width: 768px) {
    .main_area .content_inner h1 {
        font-size: 6.5vw;
    }

    .main_area .content_inner p {
        font-size: 2.7vw;
    }
}
   
@media only screen and (min-width: 1px) and (max-width: 576px) {
    body {
        font-size: 1.4rem;
    }
    .u-block--sm {
        display: block;
    }

    .u-none--sm {
        display: none;
    }

    .p-header,
    .p-m_navigation {
        background-color: #fff;
    }

    .m_navigationMenu {
        padding: 16px;
    }
    
    .aboutus_wrapper .content_parts h1 {
        margin-bottom: 40px;
        line-height: 1.5;
        font-size: 3.2rem;
        font-weight: bold;
    }

    .aboutus_wrapper .txt_area p {
        font-size: 1.2rem;
    }
    .txt_area,
    .container_wrapper .service_wrapper {
        width: 90%;
        margin: 0 auto;
        padding: 0;
    }
    
    .main_area .content_wrapper {
        height: 720px;
        background-image: url(//cdn.peraichi.com/userData/55006a06-8c24-4cc9-b824-15ea0a000007/img/39721350-3ad2-013e-5859-0a58a9feac02/w375.png);
        background-size: cover;
    }

    .main_area .content_inner .vision_text_img {
        width: 80%;
        left: 0;
    }

    .main_area .content_inner .txt_wrapper {
        position: relative;
        left: 8px;
    }

    .main_area .content_inner p {
        font-size: max(14px, min(1.83vw, 22px));
    }

    .container_wrapper {
        margin: 80px 0;
    }

    .container_wrapper .sectionTitle_wrapper {
        background-size: contain;
        background-repeat: no-repeat;
        height: 60px;
        margin: 0 0 54px 0;
        font-size: 2.4rem;
    }

    .service_wrapper .content_inner {
        display: block;
    }

    .service_wrapper .content_parts {
        margin: 0 0 40px 0;
        width: 100%;
    }

    .service_wrapper .content_parts .txt_area {
        padding: 24px 24px 72px;
    }

    h3 {
        margin: 0 0 24px 0;
        font-size: 2.0rem;
    }

    .recruit_wrapper .img_area {
        min-height: 260px;
    }

    .m_navigationMenu li {
        margin: 0;
    }

    .m_navigationMenu li:last-child {
        border-bottom: none;
    }

    .m_navigationMenu li:last-child a {
        margin-top: 16px;
    }

    .aboutus_list ul li {
        display: block;
    }

    .container_wrapper .vision_wrapper {
        display: block;
    }

    .container_wrapper .vision_wrapper .txt_wrapper {
        margin-top: 20px;
    }

    .board_wrapper .content_parts .introduction_parts {
        margin: 0 20px 20px 0;
        width: calc(100% / 2 - 10px);
    }

    .board_wrapper .content_parts .introduction_parts:nth-of-type(2n) {
        margin-right: 0;
    }

    .board_wrapper .content_parts .introduction_parts:nth-of-type(3) {
        margin: 0 20px 20px 0;
    }

    .board_wrapper .content_parts .introduction_parts .tag_wrapper {
        display: inline-block;
    }

    .board_wrapper .content_parts .introduction_parts .tag_wrapper span {
        display: inline-block;
        margin: 0 8px 8px 0;
    }

    .overview_wrapper .content_parts dl dt {
        float: none;
        width: 100%;
        font-weight: bold;
        margin: 0;
        padding: 16px 12px 0 12px;
        border-bottom: 0;
    }

    .overview_wrapper .content_parts dl dd {
        float: none;
        padding: 0 12px 16px 12px;
        width: 100%;
    }

    .overview_wrapper .content_parts dl dd:first-of-type {
        border-top: 0;
    }

    .overview_wrapper .content_parts dl dd:last-child {
        display: block;
    }

    .history_wrapper ul {
        margin: 80px 0 0 0;
    }

    .history_wrapper ul li {
        width: inherit;
        margin: 40px 0 0 20px;
        padding: 20px 0 20px 8px;
    }

    .history_wrapper ul li h4 {
        margin: 0 0 0 8px;
        font-size: 2.0rem;
    }

    .history_wrapper ul li h5 {
        margin: 0 20px 0 0;
    }

    .aboutus_list ul li h4 {
        margin: 0 0 20px 0;
    }

    .aboutus_list ul li .list_inner {
        margin: 32px 0 0 0;
    }

    .aboutus_list ul li .list_inner div {
        margin: 0 0 40px 0;
    }

    .aboutus_list ul li .list_inner div h5 {
        margin: 0;
    }

    .serviceDetails_wrapper .img_wrapper {
        width: inherit;
    }

    .serviceCatalog_wrapper ul li {
        display: block;
        width: 100%;
        margin: 0 0px 80px 0;
    }

    .backgoundColor_area {
        margin-top: 174px;
    }

    .footer-wrapper ul {
        display: block;
    }

    .footer-wrapper {
        padding: 40px 0;
    }

    .footer-wrapper ul li.isms {
        margin-top: 8px;
    }
}

/*/* 20250623 フッター*/

.footer-wrapper {
  background-color: #14c3dc;
  color: #fff;
  padding: 40px;
  font-size: 14px;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.footer-inner ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.footer-inner li {
  white-space: nowrap;
}

.footer-inner a {
  color: #fff;
  text-decoration: none;
}

.footer-inner a:hover {
  text-decoration: underline;
}

.footer-inner img {
  vertical-align: middle;
  margin-left: 4px;
  height: 12px;
}

.footer-inner .isms {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.footer-inner .isms img {
  height: 40px;
  width: auto;
  flex-shrink: 0;
  margin-left: 0;
}

@media (max-width: 768px) {
  .footer-inner ul {
    flex-direction: column;
    gap: 8px;
  }

  .footer-inner li {
    white-space: normal;
  }
}
