
@charset "utf-8";
/* common
-------------------------------------------- */
:root{
    --white:#ffffff;
    --black: #333333;
    --blue:#4BC9FF;
    --deepblue:#00B2FF;
    --lightblue:#F3FCFF;
    --darkblue:#628899;
    --orange:#FC8F1C;
    --gray-100:#DDDDDD;
    --gray-200:#C3C3C3;
    --gray-300:#999999;
    --gray-400:#6F6F6F;
    --border-radius:1.5rem;
}
html {
    font-size: 0.625rem;
}
body{
    font-size: 1.5rem;
    line-height: 1.75;
    font-family: Helvetica, "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
}
a:hover{
    opacity: 0.8;
}
.btn{
    background-color: var(--orange);
    color: var(--white);
    text-align: center;
    border-radius: 4rem;
    padding:1.4rem 3.6rem 1.4rem 3.6rem;
    display: inline-block;
    margin-block:2.4rem;
    border:0.2rem solid var(--white);
}
.btn.has-arrow{
    padding-right: 2.4rem;
    white-space: nowrap;
}
.btn.has-arrow:after{
    content: '';
    width: 1.4rem;
    height: 1.4rem;
    display: inline-block;
    margin-left: 2rem;
    background: center left / contain url(../images/common/icon-arrow.svg) no-repeat;
    vertical-align: middle;
}
.btn-underline{
    border-bottom: 0.1rem solid var(--gray-300);
    position: relative;
    width: min(21.7rem, 100%);
    display: block;
    padding-block: 1.6rem;
}
.btn-underline:before{
    content: '';
    height: 4rem;
    width: 4rem;
    display:block;
    background-color: var(--blue);
    border-radius: 100%;
    position: absolute;
    right: 0;
    top: 1rem;
}
.btn-underline:after{
    content: '';
    position: absolute;
    right: 1.7rem;
    top: 2.45rem;
    color: var(--white);
    display: inline-block;
    border-top: 0.15rem solid var(--white);
    border-right: 0.15rem solid var(--white);
    height: 1rem;
    width: 1rem;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
    .btn_wrap{
        text-align: center
    }
    .btn-underline{
        width: 100%;
    }
}
@media screen and (min-width: 769px) {
  .is-pc {
    display: block;
  }
  .is-sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .is-pc {
    display: none;
  }
  .is-sp {
    display: block;
  }
}

.mt-1 {
  margin-top: 0.6rem;
}

.mt-2 {
  margin-top: 1.2rem;
}

.mt-3 {
  margin-top: 2.4rem;
}

.mt-4 {
  margin-top: 3.6rem;
}

.mt-5 {
  margin-top: 4.8rem;
}

.mt-6 {
  margin-top: 6rem;
}

.mb-1 {
  margin-bottom: 0.6rem;
}

.mb-2 {
  margin-bottom: 1.2rem;
}

.mb-3 {
  margin-bottom: 2.4rem;
}

.mb-4 {
  margin-bottom: 3.6rem;
}

.mb-5 {
  margin-bottom: 4.8rem;
}

.mb-6 {
  margin-bottom: 6rem;
}

.ml-1 {
  margin-left: 0.6rem;
}

.ml-2 {
  margin-left: 1.2rem;
}

.ml-3 {
  margin-left: 2.4rem;
}

.ml-4 {
  margin-left: 3.6rem;
}

.ml-5 {
  margin-left: 4.8rem;
}

.ml-6 {
  margin-left: 6rem;
}

.mr-1 {
  margin-right: 0.6rem;
}

.mr-2 {
  margin-right: 1.2rem;
}

.mr-3 {
  margin-right: 2.4rem;
}

.mr-4 {
  margin-right: 3.6rem;
}

.mr-5 {
  margin-right: 4.8rem;
}

.mr-6 {
  margin-right: 6rem;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.inner{
    width:min(108rem,calc(100% - 3rem));
    margin-inline: auto;
}
/*section.inner + section.inner{
    margin-top: 4.8rem;
}*/
section[class^="cont-"]{
    padding-block: 3.6rem 4.8rem;
}
section.inner + section[class*="is-bg-"]{
    margin-top: 3.6rem;
}
section.inner:last-child{
    margin-bottom: 6rem;
}
.center{
    text-align: center;
}
.block_image img{
    width: 100%;
}
.is-bg-lightblue{
    background-color: var(--lightblue);
}
.heading-primary-wrap{
    padding-block: 2.4rem 4.8rem;
    text-align: center;
}
.heading-primary-wrap:has(.has-icon){
    padding-left: 2.4rem;
}
.heading-primary{
    text-transform: uppercase;
    font-size: clamp(2.4rem,4vw,3.6rem);
    display: inline-block;
    line-height: 1.4;
    position: relative;
    font-weight: bold;
}
.heading-primary-en{
    color: var(--blue);
    font-weight: bold;
    text-transform: capitalize;
    margin-bottom: 0.6rem;
}
.heading-primary.has-icon:before{
    content: '';
    background-color: var(--blue);
    width: 1rem;
    height: 1rem;
    display: inline-block;
    vertical-align: middle;
    border-radius: 100px;
    position: absolute;
    top: 50%;
    left: -2.4rem;
    transform: translateY(-50%);
    box-shadow: 0 0 0 0.65rem rgb(192 199 0 / 20%);
}
.heading-secondary-item{
    font-size: 2.4rem;
    margin-bottom: 3.6rem;
    line-height: 1.6;
    font-weight: bold;
}
.flexbox{
    display: flex;
}
.flexbox:has(.block_txt):has(.block_image){
    gap: clamp(2rem, 4vw, 4.8rem);
}
@media screen and (max-width: 768px) {
    .flexbox{
        flex-direction: column;
    }
    .flexbox .block_txt,
    .flexbox .block_image{
        width: 100%;
    }
}

/* Main
-------------------------------------------- */
main {
    display: block;
}
/* header - hamburger
-------------------------------------------- */
@media screen and (max-width: 1080px) {
    .header_links_nav:not(.active) {
        display: none;
    }

    .hamburger {
        display: block;
        height: 3rem;
        width: 2rem;
        margin-left: auto;
        position: absolute;
        top: 0;
        right: 0.5rem;
        z-index: 10;
        border: none;
        background-color: transparent;
        padding: 1.75rem 2.4rem;
        box-sizing: content-box;
    }

    .hamburger.close .hamburger__line{
        background-color: transparent;   
    }

    .hamburger.close .hamburger__line::after {
        top: 0;
        transform: rotate(-45deg);
    }

    .hamburger.close .hamburger__line::before {
        top: 0;
        transform: rotate(45deg);
    }

    .hamburger__line {
        display: block;
        height: 3px;
        position: absolute;
        width: 2.4rem;
        background-color: var(--black);
    }

    .hamburger__line:before,
    .hamburger__line:after {
        content: "";
        display: block;
        height: 100%;
        position: absolute;
        width: 100%;
        background-color: var(--black);
        transition: inherit;
    }

    .hamburger__line:before {
        top: -0.8rem;
    }

    .hamburger__line:after {
        top: 0.8rem;
    }
}

/* header - blobal navigation
-------------------------------------------- */
.main_header {
    box-shadow: 0 0rem 2rem hsl(0deg 0% 0% / 7%);
    position: fixed;
    width: min(108rem, calc(100% - 3rem));
    z-index: 2;
    background-color: var(--white);
    top: 2rem;
    margin-inline: auto;
    right: 0;
    left: 0;
    border-radius: 100vh;
}

.main_header .main_header_inner {
    position: relative;
}

.main_header .main_header_inner img[alt=logo] {
    width: clamp(10rem, 24vw, 30rem);
}

.main_header .header_links_nav .btn {
    padding: 0.8rem clamp(2rem, 2vw, 2.6rem);
    font-size: clamp(1.4rem,4vw,1.6rem);
    margin-block: 0;
}

.main_header .header_links_nav .btn.has-arrow:after {
    margin-left: 1rem;
}

.main_header .header_links_nav .menu-item a {
    font-size: clamp(1.4rem,4vw,1.6rem);
}

@media screen and (min-width: 1080.01px) {
    .main_header .menu {
        display: flex;
        gap: 2rem;
    }

    .main_header .main_header_inner {
        width:calc(100% - 3rem);
        margin-inline: auto;
        display: flex;
        justify-content: space-between;
        align-items: center;
        height: 6.4rem;
        gap: 2rem;
    }

    .main_header .header_links_nav {
        display: flex;
        justify-content: flex-end;
        align-items: center;
        gap: 2rem;
    }
}

@media screen and (max-width: 1080px) {
    .main_header a:has(img[alt=logo]) {
        height: 100%;
        position: relative;
        display: flex;
        width: calc(100% - 6rem);
        align-items: center;
        padding-left: 2rem;
    }
    .main_header .main_header_inner {
        height: 6.4rem;
    }
    .main_header .main_header_inner img[alt=logo]{
        width: clamp(26rem,50vw,40rem);
    }
    header.main_header:has(.hamburger.close) .header_links_nav {
        overflow-y: scroll;
        top: -6.4rem;
        position: relative;
        z-index: -1;
        width: 100%;
        box-shadow: 0 0.5rem 1rem rgb(0 0 0 / 10%);
        padding-top: 6.4rem;
        border-radius: 4rem;
    }

    body:has(#wpadminbar) header.main_header .header_links_nav {
        top: 0;
        box-shadow: 0 0.5rem 1rem hsl(0deg 0% 0% / 5%) inset, 0 1.5rem 3rem hsl(0deg 0% 0% / 6%);
        position: relative;
    }

    .header_links_nav {
        background-color: var(--white);
        padding-block: 0.5rem 1rem;
        padding-inline: 2rem;
    }

    .header_links_nav .menu-item {
        border-bottom: 0.1rem solid var(--gray-100);
        background: url(../images/common/icon-arrow-blue.svg) no-repeat right center / 1.2rem;
    }

    .main_header .header_links_nav .menu-item a {
        padding-block: 1rem;
        padding-right: 2rem;
        display: block;
    }

    .main_header .header_links_nav .btn {
        width: min(41.4rem, 100%);
        font-size: initial;
        margin-inline: auto;
        display: block;
        padding: 1.2rem;
        margin-block: 1rem 0;
    }
}

/* Header 固定ページ
-------------------------------------------- */
.page-ttl-wrap{
  max-width: calc(100% - 3rem);
  margin-inline: auto;
  text-align: center;
  font-size: clamp(3rem,4vw,4rem);
  margin-bottom: 2.4rem;
}
.page-ttl-wrap:not(.has-bg){
    padding-block: 14rem 3.6rem;
}
.page-ttl-wrap.has-bg{
    height: clamp(13rem, 36.8vw, 43.5rem);
    border-radius: 2rem;
    background-size:cover;
    background-position: center;
    color: var(--white);
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    margin-top: 10rem;
}
.page-ttl-wrap.has-bg:before{
    content: '';
    background-color: var(--black);
    width: 100%;
    height: 100%;
    top: 0;
    display: block;
    opacity: 0.5;
    position: absolute;
}
.page-ttl-wrap.has-bg > .inner{
    position: relative;
}
.page-ttl-wrap .page_ttl{
    font-weight: bold;
}
.page-ttl-wrap.has-bg .page_ttl{
    text-shadow: 0 0 10px hsl(0deg 0% 20% / 20%);
}
/* 固定ページ MV
-------------------------------------------- */
.recruit .has-bg{
    background-image: url(../images/common/mv_recruit.webp);
}
.company .has-bg{
    background-image: url(../images/common/mv_company.webp);
}
.company_message .has-bg{
    background-image: url(../images/common/mv_company_message.webp);
}
.service .has-bg{
    background-image: url(../images/common/mv_service.webp);
}
.privacy-policy .has-bg{
    background-image: url(../images/common/mv_company.webp);
}
/* パンくず
-------------------------------------------- */
.breadcrumbs{
    max-width: calc(100% - 3rem);
    margin-inline: auto;
    margin-block:3.6rem 6rem;
}

/* Footer 固定ページ CV
-------------------------------------------- */
.page_footer_wrap{
    background:url(../images/common/cv-bg-img1.webp) center / cover no-repeat;
    border-radius: 2rem;
    padding:4.8rem 2rem 4.8rem;
    width: calc(100% - 3rem);
    margin-inline: auto;
    color: var(--white);
    position: relative;
    overflow: hidden;
}
.page_footer_wrap:before{
    content: '';
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    background-color: #1ebbff;
    z-index: 0;
    top: 0;
    left: 0;
    opacity: 0.95;
}
.page_footer_wrap:has(.heading-primary){  
    padding-top: 3.6rem;
}
.page_footer_wrap .heading-primary-wrap{
    padding-block:2.4rem;
}
.page_footer_items{
    width: min(100rem,100%);
    margin-inline: auto;
    display: flex;
    justify-content: center;
    position: relative;
}
.page_footer_item{
    width: 100%;
    text-align: center;
}
.page_footer_items:not(:has(.heading-primary-wrap)){
    justify-content: space-between;
}
.page_footer_item:not(:has(.heading-primary-wrap)){
    width: min(36rem,100%);
}
.page_footer_items .hr{
    width: 0.1rem;
    display: inline-block;
    background: var(--white);
}
.page_footer_item .ttl{
    margin-bottom: 1.2rem;
}
.page_footer_item .ttl img[alt^=icon]{
    vertical-align: middle;
    margin-right: 1.2rem;
}
.page_footer_item .ttl img[alt=icon-people]{
    width: 3.6rem;
}
.page_footer_item .heading-primary-en{
    color: var(--white);
}
@media screen and (max-width: 768px) {
    .page_footer_wrap:has(.heading-primary),
    .page_footer_wrap{
        padding-block: 1rem;
    }
    .page_footer_items{
        flex-direction: column;
    }
    .page_footer_items .hr{
        width: initial;
        height: 0.1rem;
        margin-top: 1.2em;
    }
    .page_footer_items .hr + .page_footer_item{
        padding-top: 2.4rem;
    }
    .page_footer_item:not(:has(.heading-primary-wrap)){
        width: 100%;
    }
    .page_footer_wrap .heading-primary-wrap{
        padding-block: 1.4rem;
    }
    .page_footer_item .ttl{
        margin-bottom: 0;
    }
    .page_footer_item .btn.has-arrow{
        margin-block: 1.4rem;
    }
}

/* Footer
-------------------------------------------- */
.main_footer .footer-info-wrap{
    display: flex;
    justify-content: space-between;
    padding-block: 6rem 2.4rem;
}
.main_footer .footer-info{
    width:calc(100% - 310px);
}
.main_footer .footer-nav-wrap{
    width: 310px;
    display: grid;
    grid-template-columns: repeat(2, auto);
    grid-auto-rows: 4.8rem;
    grid-auto-flow: dense;
    gap: 0 2.4rem;
}
.main_footer .footer-info img.logo{
    width: min(24rem, 100%);
}
.main_footer .footer-nav-item ul li{
    font-size: 1.3rem;
    color: var(--gray-400);
    margin-top: 0.6rem;
}
.main_footer .footer-nav-item:nth-child(1){
    grid-column: 1 / 2;
    grid-row: 1 / 4;
}
.main_footer .footer-nav-item:not(:nth-child(1)){
    grid-column: 2 / 3;
}
.main_footer .footer-nav-item:nth-child(2){
    grid-row: 1 / 2;
}
.main_footer .footer-nav-item:nth-child(3){
    grid-row: 2 / 3;
}
.main_footer .footer-nav-item:nth-child(4){
    grid-row: 3 / 4;
}
.main_footer .footer-adress{
    margin-block: 2.4rem;
}
.main_footer .footer-contact a img{  
    vertical-align: middle;
    width: 1.5rem;
    margin-right: 0.8rem;
}
.main_footer .footer-sns{
    display: flex;
    padding-block: 1.2rem 3.6rem;
    gap: 0 1.2rem;
}
.main_footer .footer-outro{
    display: flex;
    justify-content: space-between;
    font-size: 1.2rem;
    color: var(--gray-400);
    padding-block: 2.4rem;
}
.main_footer .footer-link{
    display: inline-block;
    margin-right: 2rem;
    margin-bottom: 0.5rem;
}
@media screen and (max-width: 768px) {
    .main_footer .footer-info-wrap{
        display: block;
    }
    .main_footer .footer-info{
        width: 100%;
    }
    .main_footer .footer-nav-wrap.is-pc{
        display: none;
    }
    .main_footer .footer-outro{
        flex-direction: column;
        gap: 2rem;
    }
}
