@charset "utf-8";

html {
    scroll-behavior: smooth;
    font-size: 62.5%;
}

body {
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: 1.6rem;
    line-height: 1.5;
    letter-spacing: 0em;
    color: #0a2f4f;
    overflow-x: hidden;
}

/* -----------font-----------*/
.Trykker {
    font-family: "Trykker", sans-serif;
    font-weight: 400;
    font-style: normal;
}
.EuropaBold {
    font-family: "Europa", sans-serif;
    font-weight: bold;
    font-style: normal;
}

/* -----------icomoon-----------*/
@font-face {
    font-family: "icomoon";
    src: url("../fonts/icomoon.eot?thhrnp");
    src: url("../fonts/icomoon.eot?thhrnp#iefix") format("embedded-opentype"),
        url("../fonts/icomoon.ttf?thhrnp") format("truetype"),
        url("../fonts/icomoon.woff?thhrnp") format("woff"),
        url("../fonts/icomoon.svg?thhrnp#icomoon") format("svg");
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

[class^="icon-"],
[class*=" icon-"] {
    font-family: "icomoon" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img {
    width: 100%;
    height: auto;
}

.sp {
    display: block;
}

.pc {
    display: none;
}

/* -----------共通-----------*/
.target {
    opacity: 1;
    transform: none;
}

/* 文字分割用 */
.stagger-heading .char {
    display: inline-block;
    white-space: pre-wrap;
    will-change: transform, opacity;
}

.sec_container {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
    box-sizing: border-box;
}

.to_top_btn {
    width: 45px;
    height: 45px;
    background: #fff;
    border: 1px solid #0a2f4f;
    border-radius: 50%;
    position: fixed;
    bottom: 30px;
    right: 20px;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s ease;
}

.to_top_btn.is_appear {
    opacity: 1;
    pointer-events: auto;
}

section {
    position: relative;
}

.top_sec_ttl_jp {
    font-size: 1.6rem;
    width: fit-content;
    font-weight: bold;
    /* position: relative;
    top: 0;
    margin: 0 0 20px 10px; */

    writing-mode: vertical-rl;
    position: absolute;
    top: 0;
    right: 15px;
    letter-spacing: 0.1em;
}

.top_sec_ttl_jp span {
    display: block;
    /* width: 100px;
    height: 2px;
    background: #0a2f4f;
    position: absolute;
    bottom: 50%;
    right: -10px;
    transform: translate(100%, 50%); */

    width: 2px;
    height: 50px;
    background: #0a2f4f;
    position: absolute;
    bottom: -10px;
    right: 50%;
    transform: translate(50%, 100%);
}

.lower_side_ttl {
    width: fit-content;
    font-size: 2rem;
    font-weight: bold;
    position: relative;
    top: 0;
    margin: 0 0 20px 20px;
}
.lower_side_ttl.right_side {
    left: 0px;
}

.lower_side_ttl span {
    display: block;
    width: 100px;
    height: 2px;
    background: #0a2f4f;
    position: absolute;
    bottom: -6px;
    left: 0;
}

.top_sec_ttl_en {
    font-size: 4.2rem;
    font-weight: bold;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.1em;
}

.btn_white {
    display: block;
    width: 100%;
    max-width: 212px;
    color: #0a2f4f;
    border: 2px solid #0a2f4f;
    padding: 10px 20px;
    font-size: 1.3rem;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;
    /* GSAPのfromアニメと競合しないように opacity/transform はトランジション対象から外す */
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  }
  
  @media (hover: hover) {
    .btn_white:hover {
      background-color: #0a2f4f;
      color: #fff;
      border-color: #0a2f4f;
    }
  }
.btn_navy {
    display: block;
    max-width: 288px;
    background-color: #0a2f4f;
    color: #fff;
    border: 1px solid #fff;
    padding: 15px 20px;
    font-size: 1.6rem;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;

}
@media (hover: hover) {
    .btn_navy:hover {
        background-color: #fff;
        color: #0a2f4f;
        border: 1px solid #0a2f4f;
    }
}

.btn_contact {
    display: block;
    width: 100%;
    max-width: 220px;
    background: #0a2f4f;
    color: #fff;
    border: 2px solid #fff;
    border-radius: 100px;
    padding: 12px 10px;
    margin: 0 auto;
    font-size: 1.4rem;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    gap: 10px;
    transition: all 0.3s ease;
}
.btn_contact img {
    width: 20px;
    height: 20px;
}
@media (hover: hover) {
    .btn_contact:hover {
        color: #0a2f4f;
        background: #fff;
    }
    .btn_contact:hover img {
        filter: invert(0.9);
    }
}

/* 下層MV */
.lower_mv {
    width: 100vw;
    height: 100vh;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    padding: 140px 20px 40px 20px;
    box-sizing: border-box;
}

.lower_mv_ttl {
    display: flex;
    align-items: flex-end;
    flex-direction: column;
    gap: 10px;
}

.lower_mv_ttl_en {
    font-size: clamp(3rem, 3.2vw, 4.2rem);
    font-weight: bold;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.1em;
}
.lower_mv_ttl_jp {
    font-size: clamp(1.8rem, 2vw, 2.4rem);
    font-weight: bold;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.1em;
    position: relative;
}
.lower_mv_ttl_jp::before {
    content: "";
    display: block;
    width: 50px;
    height: 2px;
    background: #0a2f4f;
    position: absolute;
    bottom: 50%;
    left: -20px;
    transform: translate(-100%, 50%);
}

.lower_mv_ttl_line {
    display: none;
    width: 50px;
    height: 2px;
    background: #0a2f4f;
}

.lower_mv_image {
    width: 100%;
    height: 100%;
    max-height: 800px;
    object-fit: cover;
    border-radius: 20px;
}

/* -----------SP header-----------*/
header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 100;
    pointer-events: none;
    transition: all 0.6s ease;
}

.header_logo {
    display: block;
    width: fit-content;
    margin: 27.5px 23px;
    pointer-events: auto;
    text-decoration: none;
    position: relative;
    z-index: 10;
}

.header_logo.is_white {
    background: #fff;
    margin: unset;
    padding: 27.5px 23px;
    box-sizing: border-box;
}

.header_logo_en {
    display: block;
    font-size: 1.5rem;
    line-height: 1.3;
    color: #0a2f4f;
    letter-spacing: 0.05em;
    margin: 0 0 8px;
}

.header_logo_ja {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 0.1em;
    color: #0a2f4f;
}
.header_logo_ja::before {
    content: "";
    display: block;
    width: 11px;
    height: 11px;
    background: #0a2f4f;
}

.header_nav_list {
    width: 100vw;
    height: 100lvh;
    background: #fff;
    position: fixed;
    top: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 7vh;
    pointer-events: none;
    box-sizing: border-box;
    transition: all 0.5s ease;
    opacity: 0;
}

.fixed_header {
    width: 100vw;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 100;
    display: none;
    gap: 10px;
    opacity: 0;
    background: #fff;
    transition: all 0.6s ease;
    /* border: 1px solid #000; */
}

.fixed_header .fixed_header_logo {
    margin: 0 0 0 32px;
    text-decoration: none;
}

.fixed_header_nav_list {
    display: flex;
}

.fixed_header .header_nav_item {
    writing-mode: horizontal-tb;
    padding: 30px 28px;
    letter-spacing: 0.1em;
}

.fixed_header .header_nav_contact {
    background: transparent;
    color: #0a2f4f;
}

.fixed_header.is_scroll {
    opacity: 1;
}

.fixed_header.is_scroll .header_logo_ja {
    margin-top: 0;
}

.header_nav_list.is_active {
    opacity: 1;
}

.header_nav_item {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 0.3em;
    color: #0a2f4f;
    text-decoration: none;
    opacity: 0;
    pointer-events: none;
    transition: all 0.5s ease;
}
.header_nav_list.is_active .header_nav_item {
    opacity: 1;
    pointer-events: auto;
}

.header_hamburger {
    width: 30px;
    height: 30px;
    position: fixed;
    top: 30px;
    right: 25px;
    pointer-events: auto;
    cursor: pointer;
    z-index: 100;
}
.header_hamburger.is_active {
    gap: 0;
}

.header_hamburger_line {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 2px;
    background: #fff;
    transition: all 0.3s ease;
}
.header_hamburger_line:nth-child(1) {
    transform: translate(-50%, calc(-50% - 3px));
}
.header_hamburger_line:nth-child(2) {
    transform: translate(-50%, calc(50% + 3px));
}

.header_hamburger.is_color .header_hamburger_line {
    background: #0a2f4f;
}
.header_hamburger.is_active .header_hamburger_line:nth-child(1) {
    transform: translate(-50%, calc(-50% + 1px)) rotate(45deg);
    background: #0a2f4f;
}
.header_hamburger.is_active .header_hamburger_line:nth-child(2) {
    transform: translate(-50%, calc(50% - 1px)) rotate(-45deg);
    background: #0a2f4f;
}

/* -----------footer-----------*/
.footer_contact {
    position: relative;
    z-index: 1;
}
.footer_contact_inner {
    background: #0a2f4f;
    padding: 50px 20px;
    margin: 0 50px 0 0;
    border-radius: 0 100px 0 0;
    color: #fff;
}

.footer_contact_message {
    margin: 30px 0;
    font-size: 1.4rem;
    font-weight: 500;
}

.footer_main {
    padding: 50px min(100px, 5vw) 30px;
    max-width: 1400px;
    margin-inline: auto;
}

.footer_main_inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;
    gap: 50px;
}

.footer_main_company {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    flex-shrink: 0;
}

.footer_main_company_name {
    font-size: 2rem;
    font-weight: bold;
    margin: 0 0 10px;
}

.footer_main_company_postcode {
    margin: 0 0 3px;
}

.footer_main_sitemap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
    row-gap: 30px;
}

.footer_main_sitemap_content {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.footer_main_sitemap_item {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1;
    color: #0a2f4f;
    text-decoration: none;
}

.footer_main_sitemap_page {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
}

.footer_main_sitemap_info {
    margin: 0 0 20px;
}

.footer_main small {
    display: block;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1;
    text-align: center;
    margin: 50px auto 0;
    letter-spacing: 0.1em;
}

/* -----------top-----------*/
.top_mv {
    width: 100vw;
    height: 100vh;
    box-sizing: border-box;
}

.top_mv_inner {
    width: 100%;
    height: 100%;
    position: relative;
}

.top_mv_wrap {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.top_mv_wrap img {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    transform: scale(1);
    transition: opacity 1s ease, transform 8s ease;
    width: 100%;
    height: 100%;
    object-fit: cover;
    will-change: opacity, transform;
}

.top_mv_wrap img.active {
    opacity: 1;
    z-index: 2;
    /* ここでは拡大は付けない。次フレームで .zooming を付けて発火させる */
}

.top_mv_wrap img.active.zooming {
    transform: scale(1.05); /* じわっと拡大 */
}

.top_mv_wrap img.inactive {
    opacity: 0;
    z-index: 1;
    transform: scale(1); /* リセット */
}

.top_mv_text {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 10;        /* 画像より確実に上 */
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 0 0 50px 20px;
    pointer-events: none; /* 画像を操作しないなら付けると誤タップ防止に有効 */
  }
.top_mv_text.sp {
    display: flex;
}
.top_mv_text.pc {
    display: none;
}

.top_mv_text span {
    display: block;
    width: fit-content;
    background: #fff;
    padding: 6px 10px;
    font-size: clamp(2rem, 3.6vw, 3rem);
    font-weight: 500;
}

.top_about {
    margin: 160px 0 0px;
    padding: 0 20px 100px 0;
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.top_about_inner {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: 120px;
    position: relative;
}

.top_about_image {
    width: 85%;
    max-height: 700px;
    object-fit: cover;
    border-radius: 0 20px 20px 0;

    margin: 0 auto 0 calc(50% - 50vw);
}

.top_about_text {
    width: 90%;
    margin: 0 0 0 20px;
    padding: 0 0 60px;
}

.top_about_bg_circle {
    position: absolute;
    top: 44%;
    left: 50%;
    transform: translateX(-50%);
    display: block;
    width: 130vw;
    height: 100vw;
    background: linear-gradient(to bottom, #eff4f8, #fff 50%);
    border-radius: 50%;
    z-index: -1;
}

.top_about_head {
    font-size: clamp(2.4rem, 3.6vw, 3rem);
    font-weight: bold;
    line-height: 1.5;
}

.top_about_message {
    max-width: 600px;
    font-weight: bold;
    font-size: clamp(1.4rem, 2.4vw, 1.6rem);
    line-height: 2.3;
    margin: 20px 0 20px;
}

.top_about_ttl {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1;
    position: absolute;
    bottom: 0;
    right: 0;
}

.top_guidance {
    margin: 0px 0 60px;
    padding: 0 0px 60px 0;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}

.top_guidance .sec_container {
    padding: 0 min(120px, 6vw);
    max-width: 1800px;
}

.top_guidance_list {
    width: 90%;
    display: flex;
    position: relative;
    justify-content: space-between;
    margin: 50px auto 70px;
    flex-direction: column;
}

.top_guidance_item_line {
    display: block;
    width: 100%;
    height: 2px;
    max-width: 550px;
    margin: 20px auto 40px;
    background: #0a2f4f;
}

.top_guidance_item_line:nth-child(2) {
    left: unset;
    right: 32.5%;
}

.top_guidance_item {
    width: 100%;
    max-width: 450px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.top_guidance_item_ttl {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1;
    background: linear-gradient(to top, #e3edf5 10px, #fff 10px);
    padding: 0 5px 6px;
    margin: 0 0 15px;
}

.top_guidance_item_message {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
}

.top_guidance_item_image {
    width: 100%;
    height: auto;
    margin: 20px 0 10px;
}

.top_guidance_item_desc {
    font-size: 1.5rem;
    font-weight: bold;
}

.top_guidance_item_method {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    background: #e3edf5;
    padding: 7px 10px;
    align-self: flex-start;
    margin: 20px 0 15px;
}

.top_guidance_item_method_list {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-self: flex-start;
    padding: 0 0 20px;
}

.top_guidance_item_method_item {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 5px;
    padding: 0 0 0 20px;
    position: relative;
}

.top_guidance_item_method_item::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 16px;
    height: 18px;
    background: url(../img/check_mark.svg) no-repeat center center / contain;
}

.top_guidance_item_method_item_span {
    width: 100%;
    font-size: 1.3rem;
    font-weight: bold;
    line-height: 0.8;
    display: block;
}

.top_guidance_simulation_ttl {
    width: fit-content;
    margin: 0 auto;
    font-size: 2rem;
    letter-spacing: 0.1em;
    font-weight: bold;
    text-align: center;
    background: linear-gradient(to top, #fdf7c5 15px, #fff 15px);
    padding: 0 10px 2px 10px;
}

.top_guidance_simulation {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.top_guidance_simulation.pc {
    display: none;
}

.top_guidance_simulation_ttl_span {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.1em;
}

.top_guidance_simulation_desc {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
    text-align: center;
    margin: 24px 0 40px;
}

.top_guidance_simulation_plan {
    width: 100%;
    max-width: 660px;
    display: flex;
    justify-content: space-between;
    gap: 5px;
    margin: 0 0 30px;
    padding: 0 0 20px;
}

.top_guidance_simulation_plan_item {
    font-size: 1.6rem;
    font-weight: bold;
    width: calc((100% - 10px) / 3);
    aspect-ratio: 1;
    text-align: center;
    background: #e3edf5;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.top_guidance_simulation_plan_item::after {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/triangle_icon.svg) no-repeat center center / contain;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 35px);
}

.top_guidance_simulation_note {
    width: min(660px, 100%);
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-sizing: border-box;
    border-radius: 20px;
    position: relative;
    z-index: 1;
    border-radius: 10px;
    padding: 20px;
    /* border: 2px dashed #0a2f4f; */
}

.border {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: visible;
}

/* CSSで角丸の角のみを作成する場合 */
/* .top_guidance_simulation_note::after,
.top_guidance_simulation_note::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 50%;
    position: absolute;
    border: 2px solid transparent;
    border-top-color: #0a2f4f;
}

.top_guidance_simulation_note::after {
    top: 0;
    left: 0;
    transform: rotate(-45deg);
}
.top_guidance_simulation_note::before {
    top: 0;
    right: 0;
    transform: rotate(45deg);
}

.border_bottom_corner::after,
.border_bottom_corner::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 50%;
    position: absolute;
    border: 2px solid transparent;
    border-top-color: #0a2f4f;
} */

.border_bottom_corner::after {
    bottom: 0;
    left: 0;
    transform: rotate(225deg);
}
.border_bottom_corner::before {
    bottom: 0;
    right: 0;
    transform: rotate(-225deg);
}

.top_guidance_simulation_note_ttl {
    width: min(400px, 100%);
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1;
    padding: 0 0 10px;
    margin: 0 0 15px;
    border-bottom: 2px solid #0a2f4f;
}

.top_guidance_simulation_note_list {
    width: min(400px, 100%);
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.8;
}

.top_guidance_simulation_note_desc {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
    text-align: center;
    margin: 40px auto 0;
}

.top_service {
    position: relative;
    padding: 0 0 60px 0;
}

.top_service .sec_container {
    padding: 0 50px;
    max-width: unset;
}

.top_service_ttl {
    text-align: left;
}

.top_service_ttl_jp {
    left: 15px;
}

.top_service_list {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 30px;
    border-radius: 20px;
    overflow: hidden;
    margin: 50px auto 0;
}

.top_service_item {
    width: 100%;
    max-width: 460px;
    margin-inline: auto;
    height: 400px;
    position: relative;
}

.top_service_item_ttl {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.3em;
    writing-mode: vertical-rl;
    text-orientation: upright;
    color: transparent; /* ← 最初はテキストも透明 */
    background: transparent; /* ← 最初は背景も透明 */
    position: absolute;
    top: 20px;
    right: 20px;
    padding: 10px;
    overflow: hidden; /* マスクはみ出し防止 */
    --reveal-color: #0a2f4f; /* 文字色と同色 */
}

.top_service_item_ttl .reveal-mask {
    position: absolute;
    inset: 0;
    background: var(--reveal-color);
    transform-origin: left center;
    transform: scaleX(0);
    opacity: 0; /* ← 最初はマスクも透明 */
    pointer-events: none;
    z-index: 1; /* テキストより上でワイプ */
}

.top_service_item:nth-of-type(1) {
    background: url(../img/top_service1.webp) no-repeat center center / cover;
}
.top_service_item:nth-of-type(2) {
    background: url(../img/top_service2.webp) no-repeat center center / cover;
}
.top_service_item:nth-of-type(3) {
    background: url(../img/top_service3.webp) no-repeat center center / cover;
}

.top_blog {
    margin: 60px 0;
    position: relative;
    z-index: 1;
}

.top_blog_ttl_jp {
    left: 0px;
}

.top_blog .sec_container {
    padding: 0 20px;
    max-width: unset;
}

.top_blog_ttl {
    text-align: left;
}

.top_blog_list {
    max-width: 700px;
    margin: 50px auto 0;
}

.top_blog_item {
    color: #0a2f4f;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding: 20px 0;
    border-bottom: 2px solid #e3edf5;
    letter-spacing: 0.1em;
}

.top_blog_item_head {
    display: flex;
    align-items: center;
    gap: 10px;
}

.top_blog_item_head_date {
    font-size: 1.2rem;
    font-weight: bold;
}

.top_blog_item_head_category {
    font-size: 1rem;
    font-weight: bold;
    padding: 5px;
    background: #e3edf5;
    border-radius: 2px;
}

.top_blog_item_ttl {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.top_recruit {
    margin: 100px 0 120px;
    position: relative;
    z-index: 1;
}

.top_recruit .sec_container {
    padding: 0 50px;
    max-width: unset;
}

.top_recruit_ttl_jp {
    left: 15px;
}

.top_recruit_ttl {
    text-align: left;
}

.top_recruit_container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    gap: 40px;
}

.top_recruit_inner {
    width: 100%;
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: space-between;
    gap: 30px;
}

.top_recruit_image {
    width: 100%;
    max-height: 450px;
    border-radius: 20px;
    object-fit: cover;
}

.top_recruit_message {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.3;
    text-align: center;
}

/* -----------about-----------*/
.about_mv .lower_mv_image {
    object-position: left;
}

.about_greeting {
    overflow: hidden;
    margin: 40px 0 0 0;
}

/* about_greeting recruitページ兼用 */
.about_greeting_bg_circle {
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    display: block;
    width: 130vw;
    max-width: 1300px;
    height: 100vw;
    max-height: 1300px;
    background: linear-gradient(to bottom, #eff4f8, #fff 50%);
    border-radius: 50%;
    z-index: -1;
}

.about_greeting_inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 40px;
    padding: 100px 30px 50px 30px;
}

.about_greeting_head {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1;
}

.about_greeting_message {
    font-size: clamp(1.4rem, 2.4vw, 1.6rem);
    font-weight: bold;
    line-height: 2.3;
    text-align: center;
}

.about_cheer {
    padding: 100px 0px;
}

.about_cheer_inner {
    display: flex;
    flex-direction: column-reverse;
    gap: 30px;
    position: relative;
    padding: 0 0 0 20px;
}

.about_cheer_image {
    width: 100%;
    max-height: 700px;
    object-fit: cover;
    border-radius: 20px 0 0 20px;
}

.about_cheer_text {
    width: calc(100% - 20px);
    padding: 0 0px 0px;
}

.about_cheer_head {
    font-size: clamp(2.4rem, 3.6vw, 3rem);
    font-weight: bold;
    line-height: 1;
}

.about_cheer_message {
    font-size: clamp(1.4rem, 2.4vw, 1.6rem);
    line-height: 2.3;
    font-weight: bold;
    margin: 20px 0 20px;
}

.about_gallery {
    position: relative;
    overflow: hidden;
}

.about_gallery_inner {
    display: flex;
    animation: galleryFlow 50s infinite linear;
}

.about_gallery_image {
    width: 65%;
    aspect-ratio: 1;
    display: block;
}

@keyframes galleryFlow {
    0% {
        transform: translateX(0%);
    }
    100% {
        transform: translateX(-260%);
    }
}

.about_company {
    margin: 100px 0px 100px;
}

.about_company_list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 30px auto 0;
    padding: 0 20px;
}

.about_company_item {
    width: min(800px, 100%);
    display: flex;
    justify-content: flex-start;
    flex-direction: column;
    gap: 8px;
    padding: 10px 8px;
    box-sizing: border-box;
    border-bottom: 1px solid #0a2f4f;
}
.about_company_item:last-child {
    border-bottom: none;
}

.about_company_item_ttl {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.3;
    width: min(280px, 20vw);
    flex-shrink: 0;
}

.about_company_item_content {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    gap: 5px;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.3;
}

.about_company_item_content_map {
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1;
    color: #0a2f4f;
    text-underline-offset: 3px;
    display: flex;
    align-items: center;
    gap: 3px;
}

.about_company_item_content_map img {
    width: fit-content;
    height: 16px;
}

/* -----------service-----------*/
.service_mv .lower_mv_image {
    object-position: -150px;
}

.service_list:last-child {
    margin: 0 0 80px;
}

.service_list_inner {
    padding: 60px min(100px, 5vw);
    background: linear-gradient(to bottom, #eff4f8, #fff 50%);
}

.service_list_item {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: 30px;
}

.service_list_item_content {
    width: 100%;
    max-width: 960px;
}

.service_list_item_head {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    gap: 10px;
    border-bottom: 2px solid #0a2f4f;
    padding: 0 0 20px;
}

.service_list_item_head_num {
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1;
}

.service_list_item_head_ttl {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
}

.service_list_item_head_ttl_large {
    font-size: 2.6rem;
    font-weight: bold;
    line-height: 1;
}

.service_list_item_point {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-self: flex-start;
    padding: 30px 0 0;
}

.service_list_item_point_text {
    width: fit-content;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 5px;
    padding: 0 0 0 25px;
    position: relative;
}

.service_list_item_point_text .yellow_bg {
    background: linear-gradient(to top, #fdf7c5 7px, transparent 7px);
    padding: 0 0 2px;
}

.service_list_item_point_text::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    background: url(../img/check_mark.svg) no-repeat center center / contain;
}

.service_list_item_point_text_span {
    width: 100%;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 0.8;
    display: block;
}

.service_list_item_desc {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.8;
    margin: 30px 0 0;
}

.service_list_item_image {
    width: 100%;
    max-width: 600px;
    max-height: 450px;
    object-fit: cover;
    border-radius: 20px;
}
#service_item1 .service_list_item_image {
    object-position: bottom;
}

/* -----------recruit-----------*/
.lower_mv.recruit_mv {
    height: unset;
    padding: 140px 0px 100px 0px;
    gap: 70px;
    justify-content: flex-start;
    overflow: hidden;
}

.recruit_gallery {
    position: relative;
    align-self: flex-start;
}

.recruit_gallery_inner {
    display: flex;
    animation: recruitGalleryFlow 40s infinite linear;
}

.recruit_gallery_image {
    width: 90%;
    aspect-ratio: 1;
    display: block;
}

@keyframes recruitGalleryFlow {
    0% {
        transform: translateX(0%);
    }
    100% {
        transform: translateX(-360%);
    }
}

.recruit_greeting {
    margin: 0px 0px 80px 0px;
}

.recruit_greeting_head {
    text-align: center;
    font-size: 2rem;
}

.recruit_job {
    margin: 60px 20px 60px 20px;
}

.recruit_job_ttl {
    width: fit-content;
    font-size: 2.6rem;
    font-weight: bold;
    line-height: 1.1;
    margin: 0 auto 30px;
    padding: 0 0 15px;
    border-bottom: 2px solid #0a2f4f;
}

.recruit_job_content {
    max-width: 1400px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    gap: 40px;
    background: #f1f7fb;
    padding: 20px;
    border-radius: 20px;
    margin: 0 auto;
}

.recruit_job_content_text {
    width: 100%;
}

.recruit_job_content_text_ttl {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.recruit_job_content_text_desc {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.6;
    margin: 20px 0 0;
}

.recruit_job_content_image {
    width: 100%;
    max-height: 500px;
    object-fit: cover;
    border-radius: 10px;
}

.recruit_job .btn_navy {
    margin: 30px auto 0 auto;
}

.recruit_job_bottom {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.6;
    margin: 50px 0 0;
    text-align: center;
}

.recruit_info .about_company_item {
    align-items: flex-start;
}

.recruit_info .about_company_item_ttl {
    font-weight: bold;
}

.recruit_info .about_company_item_content {
    align-items: baseline;
    gap: 0;
    font-weight: bold;
    line-height: 1.5;
}


.recruit_consultation {
    font-size: 1.3rem;
    font-weight: bold;
    line-height: 1.3;
}

.recruit_info_bottom {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.4;
    margin: 40px 0 60px;
    text-align: center;
}

.recruit_info .btn_navy {
    margin: 0px auto 0;
}

/* -----------blog-----------*/
.blog_mv .lower_mv_image {
    object-position: -150px;
}

.blog_list {
    padding: 0 0 100px;
    min-height: 110px;
}

.pagination {
    display: flex;
    justify-content: center;
    margin: 50px 0 0;
    list-style: none;
    gap: 10px;
}

.pagination ul {
    display: flex;
    gap: 6px;
    padding: 0;
    margin: 0;
    list-style: none;
}

.pagination li {
    display: inline-block;
    display: flex;
    align-items: center;
}

.pagination a,
.pagination span {
    display: inline-block;
    padding: 8px 12px;
    text-decoration: none;
    color: #0a2f4f;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
}

.page-numbers .current {
    width: 50px;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    background: #e3edf5;
    border-radius: 50%;
}

.pagination .prev {
    margin-right: auto; /* 左寄せ */
}

.pagination .next {
    margin-left: auto; /* 右寄せ */
}

.pagination .prev,
.pagination .next {
    height: 100%;
    letter-spacing: 0.1em;
    box-sizing: border-box;
    border-radius: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.pagination .prev-arrow,
.pagination .next-arrow {
    padding: 0;
}

.pagination .prev-text,
.pagination .next-text {
    display: none;
}

@media (hover: hover) {
    .pagination .prev:hover,
    .pagination .next:hover {
        background: #0a2f4f;
    }
    .pagination .prev:hover .prev-text,
    .pagination .next:hover .next-text {
        color: #fff;
    }
}

/* -----------single-----------*/
.single_content {
    padding: 0 20px 100px;
}

.single_content_ttl {
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.3;
    letter-spacing: 0.1em;
}

.single_content_info {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    margin: 10px 0 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    letter-spacing: 0.1em;
}

.single_content_info_category {
    display: flex;
    gap: 10px;
}

.single_content_info_category a {
    display: block;
    text-decoration: none;
    color: #0a2f4f;
    background: #e3edf5;
    padding: 10px 25px;
}

.single_content_body {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
}

.single_content_body h2 {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1;
    margin: 20px 0 30px;
}

.single_content_body h3 {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
    margin: 30px 0 15px;
}

.single_content_body p {
    margin: 15px 0 0;
}

.single_content_back {
    width: 280px;
    height: 56px;
    margin: 100px auto 0px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    font-weight: bold;
}

.single_content_back a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #0a2f4f;
    background: #fff;
    border: 2px solid #0a2f4f;
    transition: all 0.3s ease;
}

@media (hover: hover) {
    .single_content_back a:hover {
        background: #0a2f4f;
        color: #fff;
    }
}

/* -----------privacy-----------*/
.privacy_mv {
    height: unset;
}

.privacy_content {
    padding: 0 20px 100px 20px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.privacy_content_desc {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.8;
}

.privacy_content_item_ttl {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
    margin: 0 0 10px;
}

.privacy_content_item_desc {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
}

.privacy_content_item_list {
    display: flex;
    gap: 5px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
}

.privacy_content_item_list_num {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
}

.privacy_content_item_list_second {
    display: flex;
    gap: 5px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
    padding: 0 0 0 18px;
}

.privacy_content_item_list_third {
    display: flex;
    gap: 5px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 2;
    padding: 0 0 0 36px;
}

.privacy_content_item_list_third .privacy_content_item_list_num {
    width: 15px;
    text-align: right;
}

.privacy_content_back {
    width: 280px;
    height: 56px;
    margin: 50px auto 0px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    font-weight: bold;
}

.privacy_content_back a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #0a2f4f;
    background: #fff;
    border: 2px solid #0a2f4f;
    transition: all 0.3s ease;
}

@media (hover: hover) {
    .privacy_content_back a:hover {
        background: #0a2f4f;
        color: #fff;
    }
}

/* -----------contact-----------*/
.contact_mv {
    height: unset;
}

.contact_content {
    max-width: 620px;
    margin: 0 auto;
    padding: 0 20px 60px 20px;
}

.contact_content_desc {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.8;
    margin: 0 0 50px;
    text-align: center;
}

.contact_content_required {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.required_mark {
    display: inline-block;
    width: 10px;
    height: 10px;
    background: #fdf7c5;
    border-radius: 50%;
    margin: 0 0 0 10px;
    position: relative;
    top: -1px;
}

.contact_content_form input,
.contact_content_form select,
.contact_content_form textarea {
    width: 100%;
    box-sizing: border-box;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.1em;
    line-height: 1;
    padding: 15px 12px;
    border-radius: 5px;
    background: #f6f6f6;
    color: #0a2f4f;
    border: none;
    resize: none;
}

.form_label {
    font-size: 1.6rem;
    font-weight: bold;
}

.contact_content_form .input_group {
    gap: 15px;
    display: flex;
    margin: 8px 0 0;
}

.contact_content_form .input_group .wpcf7-form-control-wrap {
    width: 100%;
    flex-grow: 1;
}

.contact_form_wrapper {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.form_label {
    position: relative;
}

.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder {
    color: #8e8e8e;
    font-weight: 500;
}

.wpcf7 select.placeholder-active {
    color: #8e8e8e;
    font-weight: 500;
}
/* 実際の選択肢が選ばれたときの色 */
.wpcf7 select {
    color: #0a2f4f;
    appearance: none; /* ブラウザデフォルト矢印非表示 */
    -webkit-appearance: none;
    -moz-appearance: none;
}

.custom-checkbox .wpcf7-list-item {
    margin: 0;
}
.custom-checkbox .wpcf7-list-item input {
    margin: 0 6px 0 0;
}

.form-submit {
    width: 100%;
    text-align: center;
}
.form-submit input {
    display: block;
    width: 80%;
    max-width: 470px;
    font-size: 1.8rem;
    font-weight: bold;
    background: #0a2f4f;
    color: #fff;
    margin: 0 auto;
    border-radius: 10px;
    padding: 16px;
}

.selectbox .wpcf7-form-control-wrap {
    position: relative;
}

.selectbox .wpcf7-form-control-wrap::after {
    content: "▼";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 12px;
    color: #aaaaaa;
}

.privacypolicy_agree {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1;
    display: flex;
    align-items: center;
    gap: 6px;
}

.privacypolicy_agree_link {
    color: #0a2f4f;
    text-underline-offset: 2px;
}


/* input をブラウザ標準からリセット */
.custom-checkbox input[type="checkbox"] {
    appearance: none;        /* デフォルトUIを消す */
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 15px;
    height: 15px;
    border: 1px solid #3B3B3B;
    border-radius: 2px;
    background: #fff;
    cursor: pointer;
    position: relative;
    vertical-align: middle;
    margin-right: 4px;
    padding: 0;
}

/* チェック状態 */
.custom-checkbox input[type="checkbox"]:checked {
    background-color: #298be2;
    border-color: #298be2;
}

/* チェックマーク */
.custom-checkbox input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    left: 4px;
    top: 0.6px;
    width: 3px;
    height: 8px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}


/* -----------iphon5/se-----------*/

@media screen and (min-width: 270px) {
}

/* -----------iphon6~-----------*/

@media screen and (min-width: 330px) {
}

/* -----------ipad-----------*/

@media screen and (min-width: 640px) {
    .sp {
        display: block;
    }

    .pc {
        display: none;
    }

    /* -----------共通-----------*/
    .btn_white {
        max-width: 288px;
        font-size: 1.6rem;
    }

    .btn_contact {
        max-width: 300px;
        margin: 0 0 0 auto;
        padding: 15px 10px;
    }

    .to_top_btn {
        width: 60px;
        height: 60px;
    }

    .top_sec_ttl_jp {
        font-size: 1.8rem;
        font-weight: bold;
        writing-mode: vertical-rl;
        position: absolute;
        top: 0;
        right: 25px;
        letter-spacing: 0.1em;
    }

    .top_sec_ttl_jp span {
        display: block;
        width: 2px;
        height: 80px;
        background: #0a2f4f;
        position: absolute;
        bottom: -10px;
        right: 50%;
        transform: translate(50%, 100%);
    }

    .lower_mv {
        padding: 170px 50px 90px 50px;
        gap: 50px;
    }

    .lower_mv_ttl {
        flex-direction: row;
        align-items: center;
    }

    .lower_mv_ttl_jp {
        font-size: clamp(1.8rem, 2vw, 2.4rem);
        font-weight: bold;
        line-height: 1;
        text-align: center;
        letter-spacing: 0.1em;
    }

    .lower_mv_ttl_line {
        display: block;
    }

    .lower_mv_ttl_jp::before {
        display: none;
    }

    /* -----------SP header-----------*/
    .header_hamburger {
        right: 35px;
    }

    /* -----------footer-----------*/
    .footer_contact_inner {
        padding: 80px min(100px, 5vw);
        margin: 0 100px 0 0;
    }

    .footer_contact_message {
        font-size: 1.6rem;
    }

    .btn_contact {
        font-size: 1.6rem;
    }

    .footer_main {
        padding: 100px min(100px, 5vw) 70px;
    }

    .footer_main_inner {
        justify-content: space-around;
        flex-direction: row;
    }

    .footer_main small {
        margin: 100px auto 0;
    }

    /* -----------top-----------*/
    .top_mv {
        padding: 0 0 100px 30px;
    }

    .top_mv_text {
        margin: 0 0 50px 30px;
        gap: 20px;
    }
    .top_mv_text.sp {
        display: none;
    }
    .top_mv_text.pc {
        display: flex;
    }

    .top_about {
        margin: 100px 0;
        padding: 0 80px 100px 0;
    }

    .top_about_ttl {
        font-size: 4.2rem;
    }

    .top_about_text {
        width: 90%;
        margin: 0 0 0 auto;
    }

    .top_guidance {
        padding: 0 20px 60px 0;
    }

    .top_guidance_simulation.pc {
        display: block;
    }

    .top_guidance_simulation_ttl {
        font-size: 3rem;
    }

    .top_guidance_simulation_ttl_span {
        font-size: 2rem;
    }

    .top_guidance_simulation_plan {
        gap: 30px;
        margin: 0 0 60px;
    }

    .top_guidance_simulation_plan_item {
        width: calc((100% - 60px) / 3);
        font-size: 2.4rem;
    }

    .top_guidance_simulation_plan_item::after {
        width: 40px;
        height: 40px;
        transform: translate(-50%, 60px);
    }

    .top_guidance_simulation_note {
        padding: 30px;
    }

    .top_guidance_simulation_note_ttl {
        font-size: 2rem;
    }

    .top_guidance_simulation_note_list {
        font-size: 2rem;
    }

    .top_guidance_simulation_note_desc {
        margin: 70px auto 0;
    }

    .top_service_ttl_jp {
        left: 25px;
    }

    .top_service .sec_container {
        padding: 0 min(120px, 6vw) 0 80px;
        max-width: unset;
    }

    .top_blog_ttl {
        text-align: right;
    }

    .top_blog_item_ttl {
        font-size: 1.6rem;
    }

    .top_blog .sec_container {
        padding: 0 min(120px, 8vw) 0 80px;
        max-width: unset;
    }

    .top_blog_ttl_jp {
        right: 25px;
    }

    /* .top_recruit_image {
        width: 60%;
    } */

    .top_recruit_message {
        font-size: 2.4rem;
    }

    /* -----------about-----------*/
    .about_greeting_head {
        font-size: clamp(3rem, 3.6vw, 4rem);
    }

    .about_gallery_inner {
        animation: galleryFlow 50s infinite linear;
    }

    .about_gallery_image {
        width: 30%;
    }

    @keyframes galleryFlow {
        0% {
            transform: translateX(0%);
        }
        100% {
            transform: translateX(-120%);
        }
    }

    .about_company {
        margin: 150px 0px;
        padding: 50px 0 0px;
    }

    .about_company_list {
        margin: 50px auto 0;
    }

    .about_company_item {
        flex-direction: row;
        align-items: center;
        padding: 15px 30px;
    }

    .about_company_item_content {
        flex-direction: row;
        align-items: center;
        gap: 10px;
    }

    /* -----------service-----------*/
    .service_mv .lower_mv_image {
        object-position: center;
    }

    /* -----------recruit-----------*/
    .recruit_mv.lower_mv {
        gap: 100px;
    }

    .recruit_gallery_inner {
        animation: recruitGalleryFlow 50s infinite linear;
    }

    .recruit_gallery_image {
        width: 30%;
    }
    
    @keyframes recruitGalleryFlow {
        0% {
            transform: translateX(0%);
        }
        100% {
            transform: translateX(-120%);
        }
    }

    .recruit_greeting {
        margin: 80px 0px 80px 0px;
    }

    .recruit_job {
        margin: 80px 50px 80px 50px;
    }

    .recruit_job_ttl {
        font-size: 3.2rem;
    }

    .recruit_job_content {
        padding: 30px;
    }

    .recruit_job_content_text_ttl {
        font-size: 3rem;
    }

    .recruit_job_content_text_desc {
        font-size: 1.6rem;
        margin: 30px 0 0;
    }

    .recruit_job_bottom {
        font-size: 1.8rem;
    }

    .recruit_info_bottom {
        font-size: 1.5rem;
        margin: 70px 0 100px;
    }

    /* -----------blog-----------*/
    .blog_mv .lower_mv_image {
        object-position: center;
    }

    .pagination ul {
        gap: 10px;
    }

    .pagination .prev,
    .pagination .next {
        width: 150px;
        border: 1px solid #0a2f4f;
    }

    .pagination .prev-text,
    .pagination .next-text {
        display: block;
    }

    .pagination .prev-arrow,
    .pagination .next-arrow {
        display: none;
    }

    /* -----------single-----------*/
    .single_mv {
        padding: 170px 40px 40px 40px;
        max-width: 1200px;
        margin-inline: auto;
    }

    .single_content {
        padding: 0 50px 150px;
        max-width: 1000px;
        margin-inline: auto;
    }

    .single_content_ttl {
        font-size: 3rem;
    }

    .single_content_info {
        font-size: 1.6rem;
        gap: 20px;
    }

    .single_content_back {
        margin: 150px auto 50px;
    }

    /* -----------privacy-----------*/
    .privacy_content {
        padding: 0 40px 150px 40px;
        gap: 50px;
        max-width: 1000px;
        margin-inline: auto;
    }

    .privacy_content_desc {
        font-size: 2rem;
        line-height: 2;
    }

    .contact_content_desc {
        font-size: 2rem;
        line-height: 2;
    }

    /* -----------contact-----------*/
    .contact_content_required {
        padding: 0 50px 0 0;
    }
}

/* -----------PC-----------*/

@media screen and (min-width: 960px) {
    body {
        font-size: 15px;
    }

    .sp {
        display: none;
    }

    .pc {
        display: block;
    }

    /* -----------共通-----------*/

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

    /* -----------footer-----------*/

    /* -----------top-----------*/
    .top_about_head {
        line-height: 1;
    }

    .top_guidance_list {
        flex-direction: row;
    }

    .top_guidance_item_line {
        width: 2px;
        height: 100%;
        position: absolute;
        top: 0;
        left: 32.5%;
    }

    .top_guidance_item {
        width: 30%;
        margin: unset;
    }

    .top_service_list {
        flex-direction: row;
    }

    .top_service_item {
        width: calc((100% - 60px) / 3);
        height: 460px;
        max-width: none;
        margin-inline: unset;
    }

    .top_service_item_ttl {
        font-size: 2.4rem;
    }

    .top_recruit_container {
        flex-direction: row;
    }

    .top_recruit_inner {
        width: 50%;
        gap: 50px;
    }

    .top_recruit_image {
        width: 45%;
    }

    /* -----------service-----------*/
    .service_list:last-child {
        margin: 0 0 150px;
    }

    .service_list_item {
        flex-direction: row;
        gap: min(70px, 4vw);
    }

    .service_list:nth-of-type(odd) .service_list_item {
        flex-direction: row-reverse;
    }

    .service_list_inner {
        padding: 100px min(100px, 5vw);
    }

    .service_list_item_content {
        width: max(50%, 507px);
        flex-shrink: 0;
    }

    .service_list_item_head {
        flex-direction: row;
        align-items: flex-end;
    }

    .service_list_item_head_num {
        font-size: 5rem;
    }

    .service_list_item_head_ttl {
        font-size: 3rem;
    }

    .service_list_item_head_ttl_large {
        font-size: 4rem;
    }

    .service_list_item_desc {
        font-size: 1.6rem;
    }

    .service_list_item_image {
        /* max-width: 600px; */
        width: 50%;
    }

    /* -----------recruit-----------*/
    .recruit_job_content {
        flex-direction: row;
        padding: 50px;
    }

    .recruit_job_content_text {
        width: 60%;
    }

    .recruit_job_content_text_ttl {
        text-align: left;
    }

    .recruit_job_content_image {
        width: 40%;
        max-height: unset;
    }

    .recruit_job .btn_navy {
        margin: 30px auto 0 0;
    }
}

@media screen and (min-width: 1025px) {
    .sp {
        display: none;
    }

    .pc {
        display: block;
    }

    /* -----------共通-----------*/
    .to_top_btn {
        bottom: 50px;
        right: 50px;
    }

    .top_sec_ttl_jp {
        font-size: 2rem;
        right: 50px;
    }
    .top_sec_ttl_jp span {
        height: 150px;
    }

    .lower_side_ttl {
        font-size: 2.4rem;
        font-weight: bold;
        writing-mode: vertical-rl;
        position: absolute;
        top: 0;
        left: 60px;
        letter-spacing: 0.1em;
    }

    .lower_side_ttl span {
        display: block;
        width: 2px;
        height: 100%;
        background: #0a2f4f;
        position: absolute;
        top: 0px;
        left: -20px;
    }

    .lower_side_ttl.right_side {
        left: unset;
        right: 25px;
    }

    .lower_mv {
        padding: 150px 150px 90px 50px;
    }

    /* -----------PC header-----------*/
    .header_logo {
        margin: 50px 70px;
    }

    .header_logo.is_white {
        margin: unset;
        padding: 50px 70px;
    }

    .header_logo_en {
        font-size: 1.8rem;
        letter-spacing: 0.05em;
    }

    .header_logo_ja {
        font-size: 1.3rem;
        margin: 10px 0 0;
    }
    .header_logo_ja::before {
        width: 20px;
        height: 20px;
    }

    .header_nav_list {
        width: unset;
        height: 100vh;
        background: #fff;
        position: absolute;
        top: 0;
        right: 0;
        flex-direction: column;
        justify-content: space-between;
        gap: 20px;
        padding: 80px 0 0;
        opacity: 1;
    }

    .header_nav_item {
        opacity: 1;
        flex-grow: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        writing-mode: vertical-rl;
        padding: 0 42px;
        pointer-events: auto;
    }

    .header_nav_contact {
        background: #0a2f4f;
        color: #fff;
        padding: 30px 42px;
    }

    .header_hamburger {
        display: none;
    }

    .fixed_header {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    /* -----------footer-----------*/
    .footer_contact_inner {
        margin: 0 200px 0 0;
        padding: 80px min(100px, 10vw);
    }

    .footer_contact_message {
        font-size: 2.4rem;
    }

    .footer_main_inner {
        justify-content: space-between;
        gap: 10px;
    }

    .footer_main_sitemap {
        flex-direction: row;
        gap: 40px;
    }

    .footer_main_sitemap_content {
        width: unset;
    }

    /* -----------top-----------*/
    .top_mv {
        padding: 0 0 100px 150px;
    }

    .top_mv_text {
        margin: 0 0 50px 50px;
    }

    .top_mv_text span {
        padding: 8px 20px;
    }

    .top_about {
        margin: 160px 0;
        padding: 0 120px 100px 0;
    }

    .top_about_inner {
        flex-direction: row;
        gap: 50px;
    }

    .top_about_image {
        width: 45%;
        /* max-height: 800px; */
    }

    .top_about_text {
        width: 55%;
        margin: 0;
    }

    .top_about_bg_circle {
        top: 0;
        left: 64%;
        transform: translateX(-50%);
        width: 100vw;
        height: 100vw;
    }

    .top_about_head {
        font-size: clamp(2.8rem, 2.8vw, 3rem);
    }

    .top_about_message {
        margin: 50px 0 40px;
    }

    .top_service .sec_container {
        padding: 0 min(120px, 6vw) 0 120px;
    }

    .top_service_ttl_jp {
        left: 50px;
    }

    .top_recruit .sec_container {
        padding: 0 min(120px, 8vw) 0 120px;
    }

    .top_recruit_ttl_jp {
        left: 50px;
    }

    /* -----------about-----------*/
    .about_company .lower_side_ttl {
        top: 100px;
    }

    .about_greeting_inner {
        margin: 100px 0 0 0;
        padding: 100px 20px 150px 20px;
    }

    .about_greeting_bg_circle {
        top: 0px;
    }

    .about_cheer {
        padding: 0px 0 200px 100px;
    }

    .about_cheer_inner {
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        gap: 50px;
    }

    .about_cheer_image {
        width: 45%;
    }

    .about_cheer_text {
        width: 55%;
        max-width: 700px;
        margin: 0;
    }

    .about_cheer_head {
        font-size: clamp(2.8rem, 2.8vw, 3rem);
    }

    .about_cheer_message {
        max-width: 600px;
        margin: 50px 0 0;
    }

    /* -----------single-----------*/
    .single_mv {
        padding: 240px 150px 40px 50px;
    }

    .single_content {
        padding: 0 100px 150px;
    }

    .single_content_ttl {
        font-size: 4.2rem;
    }

    .single_content_info {
        margin: 20px 0 70px;
    }

    .single_content_body h2 {
        font-size: 3rem;
        margin: 30px 0 50px;
    }

    .single_content_body h3 {
        margin: 50px 0 20px;
    }

    .single_content_body p {
        margin: 20px 0 0;
    }

    /* -----------privacy-----------*/
    .privacy_content {
        padding: 0 200px 150px 100px;
    }

    /* -----------contact-----------*/
    .contact_mv {
        padding: 177px 50px 90px 50px;
    }
}
