@charset "UTF-8";
/* =========================
全ページ共通 
============================*/
:root{
    --color-navy: #306D9E;
    --color-navy02: #14558A;
    --color-gray: #474747;
    --color-pink: #F17474;
    --color-pink02: #F05858;
    --color-orange: #E47C62;
    --color-orange02: #E56441;
    --color-orange03:#DB6A0D;
    --color-green01: #309E60;
    --color-white: #fff;
    --color-black: #111;
    --color-gradation01: linear-gradient(290deg, #e96666, #ea704f 72%, #fa894b);
    --color-gradation02: linear-gradient(253deg, #fff2ce, #ffd5c5);
    --color-bg-green: #F3FBF6;
    --s-val: 10px;
    --header-height: calc(var(--s-val) * 12);
    --sub-top-padding-top: calc(var(--header-height) + (var(--s-val) * 3));
    --sub-top-padding-bottom: calc(var(--s-val) * 6.5);
}
html{
    scroll-behavior: smooth;
}
.g-wrap{
    font-family: "Noto Sans", sans-serif;
    font-size: calc(var(--s-val) * 1.6);
}

.page-width {
    --p-inline: calc(var(--s-val) * 5);
    max-width: calc(1200px + var(--p-inline) * 2);
    margin-inline: auto;
    padding-inline: var(--p-inline);
}
.br--pc{
    display: block;
}
.br--sp{
    display: none;
}
.hover-opacity {
    transition: opacity 0.3s ease;
}
.hover-opacity:hover{
    opacity: 0.8;
}

/* =========================
下層ページ共通
============================*/
.sub-top--has_bg_image{
    position: relative;
    background: var(--color-gradation02);
    padding-block: var(--sub-top-padding-top) var(--sub-top-padding-bottom);
}

.sub-top__text{
    color: var(--color-orange);
    text-align: center;
}
.sub-top__en{
    font-size: calc(var(--s-val) * 7.2);
    letter-spacing: calc(var(--s-val) * 0.5);
}
.sub-top__ja{
    font-size: calc(var(--s-val) * 2.4);
    font-weight: bold;
    letter-spacing: calc(var(--s-val) * 0.5);
} 

/* === レスポンシブ === */
@media screen and (max-width: 768px) {
    .sub-top__en{
        font-size: calc(var(--s-val) * 4.6);
    }
    .sub-top__ja{
        font-size: calc(var(--s-val) * 2.2);
    }
}

/* =========================
ヘッダー共通 
============================*/
.g-header{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: var(--header-height);
    z-index: 100;
    background: transparent;
    transition: transform 0.3s ease,background-color 0.3s ease;
}
/* 上に隠す */
.g-header.is-hidden {
    transform: translateY(-100%);
}

.g-header.is-hidden .g-header__logo::before {
    opacity: 0;
}
/* === 法人ページ用 === */
.is-corporate .g-header__logo::before {
    opacity: 0;
 }

.g-header__inner{
    padding: 0 calc(var(--s-val) * 4) 0 calc(var(--s-val) * 1.3);
    height: 100%;
}
.g-header__container{
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
}
/* ロゴ */
.g-header__logo{
    position: relative;
    display: flex;
    align-items: center; 
    justify-content: flex-start; 
    height: 100%;
    margin: 0;
}

.g-header__logo::before {
    content: "";
    position: absolute;
    top: 60%;
    left: 66%;
    transform: translate(-50%, -50%);
    width: 240%;  
    height: 280%; 
    background-image: url("../images/common/logo-back.png");
    background-repeat: no-repeat;
    background-size: contain; 
    background-position: center;
    z-index: -1;
    pointer-events: none;
    opacity: 1; 
    transition: opacity 0.5s ease;
}
.g-header__logo img {
    height: calc(var(--s-val) * 8); 
    width: auto;   
    display: block;
}
.g-header__logo a {
    display: block;           
    height: auto;        
    width: fit-content;  
    line-height: 0;          
}

.g-nav{
    display: flex;
    align-items: center;
    background: #fff;
    padding: calc(var(--s-val) * 0.8) calc(var(--s-val) * 3.1);
    border-radius: 45.5px;
    box-shadow: 0 4px 4px 0 rgba(203,203,203,0.25);
}

.g-nav__block{
    list-style-type: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: calc(var(--s-val) * 1.7);
}

.g-nav__link{
    color: var(--color-gray);
    text-decoration: none;
    transition: 0.3s;
}

.g-nav__apply-btn{
    background: var(--color-navy);
    padding: calc(var(--s-val) * 0.9) calc(var(--s-val) * 2.1);
    border-radius: 23.5px;
    box-shadow: 0 2px 4px 0 rgba(143,143,143,0.25);
    transition: background-color 0.5s;
    margin-left: calc(var(--s-val) * 1.7);
}
/* ホバー時 */
.g-nav__link:hover{
    color: var(--color-pink);
}

.g-nav__apply-btn:hover{
    background: var(--color-pink);
}

/* ハンバーガーメニュー */
.hamburger-icon-wrap{
    position: absolute;        
    right: 0;                  
    top: 0;
    width: 5rem;
    height: 100%;
    justify-content: center;   
    align-items: center;       
    background: var(--color-gradation01);
    cursor: pointer;
    border: none;
    padding: 0;
    z-index: 110;
    display: none;
}

.hamburger-icon {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between; 
    align-items: center;          
    width: 40px;
    height: 30px;
}

.hamburger-icon .hamburger-icon__line{
    display: block;  
    width: 100%;
    height: 3px;
    background-color: #fff;
    position: absolute; 
    transition: transform 0.3s ease, top 0.3s ease, opacity 0.3s ease;
}

.hamburger-icon__line:nth-child(1) {
    top: 0;
}

.hamburger-icon__line:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
}

.hamburger-icon__line:nth-child(3) {
    bottom: 0;
}

.js-hamburger_toggle.is-open .hamburger-icon__line:nth-child(1){
    transform: rotate(45deg);
    top: 50%;
}

.js-hamburger_toggle.is-open .hamburger-icon__line:nth-child(2){
    opacity: 0;
}

.js-hamburger_toggle.is-open .hamburger-icon__line:nth-child(3){
    transform: rotate(-45deg);
    top: 50%;
}

/* === 法人ページ用 === */
.is-corporate .g-nav__apply-btn{
    background: var(--color-orange03);
    box-shadow: 0 2px 4px 0 rgba(143,143,143,0.25);
}

.g-nav__apply-btn a{
    color: var(--color-white);
    font-weight: bold;
    text-decoration: none;
}

.is-corporate .g-nav__link:hover{
    color: var(--color-orange03);
}
.is-corporate .g-nav__apply-btn:hover{
    background: var(--color-navy02);
}
.is-corporate .hamburger-icon-wrap{
    background: var(--color-bg-green);
}
.is-corporate .hamburger-icon .hamburger-icon__line{
    background-color: var(--color-gray);
}


 /* === レスポンシブ === */
  @media screen and (max-width: 768px) {
    .g-header{
        background: var(--color-white);
        box-shadow: 0 4px 4px 0 rgba(203,203,203,0.25);
    }
    .g-header__inner{
        padding: 0;
        height: 100%;
    }
    .g-header__container {
        justify-content: space-between; 
        align-items: center; 
        height: 100%;
    }
    .g-header__logo{
        margin-left: calc(var(--s-val) * 1.1);
        width: 8.5rem;
    }
    .g-header__logo img {
        height: calc(var(--s-val) * 5); 
    }
    .g-header__logo::before{
        display: none;
    }
    
    .hamburger-icon-wrap{
        display: flex;
    }
    .g-nav{
        position: fixed;
        right: 0;
        width: 70%;
        top: var(--header-height);
        height: calc(100dvh - var(--header-height));
        background: var(--color-gradation01);
        transform: translateX(100%);
        transition: none;
        opacity: 0;
        visibility: hidden;
        z-index: 90;
        border-radius: 0;
        padding: calc(var(--s-val) * 3);
        flex-direction: column;
        align-items: stretch;
        box-shadow: none;
    }
    .g-nav.is-animating {
        transition: transform 0.35s cubic-bezier(.4,0,.2,1), opacity 0.25s ease, visibility 0.35s !important;
    }

    .g-nav.is-open {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
        overflow: auto;
    }
    .g-nav.is-active:not(.is-open) {
        transform: translateX(100%);
        opacity: 0;
        visibility: hidden;
        /* 閉じる時のアニメーション */
        transition: transform 0.35s cubic-bezier(.4,0,.2,1), opacity 0.25s ease, visibility 0s linear 0.35s;
    }
    .g-nav__block{
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        margin-bottom: calc(var(--s-val) * 3);
    }

    .g-nav__item{
        border-bottom: 1px solid var(--color-white);
    }
    .g-nav__item:last-of-type{
        border-bottom: 0;
    }

    .g-nav__link{
        display: block;
        color: var(--color-white);
        font-size: calc(var(--s-val) * 1.8);
        padding: calc(var(--s-val) * 2) calc(var(--s-val) * 1.5);
        border: 2px solid transparent;

    }

    .g-nav__apply-btn{
        width: 100%;
        background: var(--color-white);
        padding: calc(var(--s-val) * 1.8) calc(var(--s-val) * 1.1);
        border-radius: calc(var(--s-val) * 2.9);
        margin-left: 0;
        box-shadow: 0 2px 4px rgba(83, 83, 83, 0.25);
    }
    .g-nav__apply-btn a{
        display: block;
        color: var(--color-pink02);
        text-align: center;
        transition: color 0.3s ease;
    }

    /* === 法人ページ用 === */
    .is-corporate .g-nav{
        background: var(--color-bg-green);
    }
    .is-corporate .g-nav__item{
        border-bottom: 1px solid var(--color-gray);
    }
    .is-corporate .g-nav__link{
        color: var(--color-gray);
    }
    .is-corporate .g-nav__apply-btn a{
        color: var(--color-white);
    }
     /* ホバー時 */    
     @media screen and (max-width: 768px) and (hover: hover) {
          .g-nav__link:hover {
            color: var(--color-white);
            opacity: 0.7;
          }
          .g-nav__apply-btn:hover{
            background-color: var(--color-white);
            border-color: var(--color-pink02);
            box-shadow: 0 10px 8px rgba(83, 83, 83, 0.25);
            transform: translateY(-2px);
          }
        }
      
    } 
    

/* =========================
 フッター
============================*/
.g-footer__nav-wrapper{
    background: var(--color-gradation01);
}
/* === 法人ページ用 === */
.is-corporate .g-footer__nav-wrapper{
    background: var(--color-bg-green);
}
.g-footer__nav-inner{
    max-width: 1200px;
    margin: 0 auto;
    padding: calc(var(--s-val) * 8.8) calc(var(--s-val) * 5);
    color: var(--color-white);
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
}

.g-footer__nav-divider{
    background-color: #fff;
    width: 1px;
    height: 100%;
    margin-inline: calc(var(--s-val) * 5) calc(var(--s-val) * 9.6);
    pointer-events: none;
}  
  

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

.g-footer__nav-left{
    display: flex;
    /* justify-content: space-between; */
}

.g-footer__nav-logo{
    margin-right: calc(var(--s-val) * 3);
    width: calc(var(--s-val) * 11);
    height: auto;
    flex-shrink: 0;
}
.g-footer__logo-link{
    display: block;
}
.g-footer__logo-link img{
    width: 100%;
    height: auto;
    display: block;
}
.g-footer__nav-text{
    font-size: calc(var(--s-val) * 1.6);
    font-style: normal;
    line-height: 1.8;
}
.g-footer__company-name{
    font-size: calc(var(--s-val) * 3.6);
    margin-bottom: calc(var(--s-val) * 1.5);
}

.g-footer__nav-right{
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: calc(var(--s-val) * 6);
    flex-wrap: nowrap;
}
.g-footer__nav-block{
    list-style-type: none;
    font-family: "Puritan", sans-serif;
    display: flex;
    flex-direction: column;
    gap: calc(var(--s-val) * 1.6);
}

.g-footer__nav-title{
    font-size: calc(var(--s-val) * 2.5);
    font-weight: bold;
}
.g-footer__nav-link{
    color: var(--color-white);
    text-decoration: none;
    font-size: calc(var(--s-val) * 2);
}
.g-footer__nav-title,
.g-footer__nav-link{
    white-space: nowrap;
}

/* === 法人ページ用 === */
.is-corporate .g-footer__nav-inner{
    color: var(--color-gray);
    padding: calc(var(--s-val) * 8.8) calc(var(--s-val) * 5)  calc(var(--s-val) * 6) calc(var(--s-val) * 5);
    border-bottom: 1px solid var(--color-gray);
}
.is-corporate .g-footer__nav-link{
    color: var(--color-gray);
}
.is-corporate .g-footer__nav-divider{
    background-color: transparent;
}
.is-corporate .g-footer__sub{
    background: var(--color-bg-green);
}
.is-corporate .g-footer__sub-inner{
    padding: calc(var(--s-val) * 2.6) 0;
}

/* ホバー時 */
.g-footer__nav-link:hover{
    opacity: 0.5;
    transition: 0.3s;
}

.g-footer__sub{
    background-color: #FCEFEB;
    text-align: center;
}

.g-footer__sub-inner{
    padding: calc(var(--s-val) * 0.6) 0;
    font-size: calc(var(--s-val) * 1.4);


}
.g-footer__sub-link{
    color: var(--color-black);
    text-decoration: none;
}
/* ホバー時 */
.g-footer__sub-link:hover{
    opacity: 0.6;
    transition: 0.3s;
}
.sp-br {
    display: inline;
}

/* === レスポンシブ === */
@media screen and (max-width: 768px) {
    .sp-br{
        display: block;
    }
    .g-footer__nav-inner{
        display: flex;
        flex-direction: column;
        gap: calc(var(--s-val) * 4.5);
    }
    .g-footer__sub-inner{
        padding: calc(var(--s-val) * 1.5) 0;
    }
    .g-footer__nav-divider{
        display: none;
    }
    .g-footer__nav-left{
        flex-direction: column;
        align-items: flex-start;
    }
    .g-footer__nav-logo {
        margin-right: 0;
        width: calc(var(--s-val) * 13);
        margin-bottom: calc(var(--s-val) * 2);
    }
    .g-footer__company-name{
        font-size: calc(var(--s-val) * 4.2);
    }
    .g-footer__nav-text {
        font-size: calc(var(--s-val) * 1.9);
    }
    .g-footer__nav-right{
     flex-direction: column;
    }
    .g-footer__nav-title{
        display: flex;
        align-items: center; 
        gap: calc(var(--s-val) * 5);
    }

    .g-footer__nav-title::after{
        content: "";
        flex: 1;                 
        height: 1px;
        background-color: var(--color-white);
    }

    /* === 法人ページ用 === */
    .is-corporate .g-footer__nav-inner{
        border-bottom: none
    }
    .is-corporate .g-footer__nav-title::after{
        background-color: var(--color-gray);
    }
    .is-corporate .g-footer__sub-inner {
        padding: calc(var(--s-val) * 1.5) 0;
    }
}


/* === レスポンシブ === */
@media screen and (max-width: 1200px) {
    :root{
        --s-val: 0.82vw
    }
  }

  @media screen and (max-width: 768px) {
    :root{
        --s-val: 2.2vw;
        --header-height: 5rem;
        --sub-top-padding-top: calc(var(--header-height) + (var(--s-val) * 5));
        --sub-top-padding-bottom: calc(var(--s-val) * 2.5);
    }
    .g-wrap{
        font-size: calc(var(--s-val) * 1.8);
    }
    .page-width {
        --p-inline: calc(var(--s-val) * 2.4);
    }
    .br--pc{
        display: none;
    }
    .br--sp{
        display: block;
    }
  }
