@charset "utf-8";

/*
 * File    : rwd-layout.css
 * Author  : STUDIO-JT (JSH)
 *
 * SUMMARY :
 * 1900px
 * 1680px
 * 1480px
 * 1200px
 * 1023px
 * 860px
 * 540px
 */



/* **************************************** *
 * 1920px
 * **************************************** */
@media (max-width: 1900px){

    /* LAYOUT */
    .wrap-wide {  max-width: inherit; margin: 0 70rem; }

    br.mgbr { display: none !important; } 

    /* HEADER */
    .header__inner { max-width: inherit; margin: 0 70rem; }
    .sticky-banner__content p { max-width: inherit; margin: 0 70rem; }
    .sticky-banner__close { right: 70rem; }

    /* FOOTER */
    .footer__inner { max-width: inherit; margin: 0 70rem; }

}



/* **************************************** *
 * 1680px
 * **************************************** */
@media (max-width: 1680px){

    /* VAR */
    :root {
        --font-size-primary-01: 64rem;
        --font-size-primary-02: 50rem;
        --font-size-primary-03: 40rem;
        --font-size-primary-04: 28rem;
        --font-size-primary-05: 26rem;

        --font-lineheight-primary-01: 82rem;
        --font-lineheight-primary-02: 62rem;
        --font-lineheight-primary-03: 54rem;
        --font-lineheight-primary-04: 42rem;
        --font-lineheight-primary-05: 39rem;
    }

    /* HEADER */
    .header__search-close { right: 70rem; }

}




/* **************************************** *
 * 1480px
 * **************************************** */
@media (max-width: 1480px){

    html,
    html.safari.desktop { font-size: 0.06756756756756757vw; }

    /* VAR */
    :root {
        --font-size-primary-01: 60rem;
        --font-size-primary-02: 44rem;
        --font-size-primary-03: 36rem;
        --font-size-primary-04: 26rem;
        --font-size-primary-05: 24rem;
        --font-size-primary-06: 20rem;

        --font-lineheight-primary-01: 76rem;
        --font-lineheight-primary-02: 54rem;
        --font-lineheight-primary-03: 48rem;
        --font-lineheight-primary-04: 39rem;
        --font-lineheight-primary-05: 36rem;
        --font-lineheight-primary-06: 32rem;
    }

    /* LAYOUT */
    .main-container { padding-top: 220rem; padding-bottom: 180rem; }

    .wrap-wide { margin: 0 50rem; }
    .wrap-moderate { max-width: inherit; margin: 0 50rem; }

    /* PAGE */
    .article__header { padding-bottom: 80rem; }
    .article__header--narrow { padding-bottom: 60rem; }
    .article__section { padding: 160rem 0 180rem; }
    body:has(.jt-cta) .article__section:last-child { padding-bottom: 180rem; }
    
    /* HEADER */
    .header__inner { margin: 0 50rem; }
    .sticky-banner__content p { margin: 0 50rem; }
    .sticky-banner__close { right: 50rem; }

    #logo { width: 200rem; height: auto; }

    #menu > li > a { padding: 30rem 22rem }
    #menu > li > ul > li > a { padding: 6rem 28rem; }
    #menu > li > ul > li:first-child > a { padding-top: 28rem; }
    #menu > li > ul > li:last-child > a { padding-bottom: 28rem; }

    .header__utils-list { gap: 10rem; }
    .header__utils-list a > .jt-icon { width: 28rem; height: 28rem; }
    .header__utils-list .header__utils-contact { padding: 8rem 28rem; }

    .header__search-container { padding: 80rem 0; }
    .header__search-close { top: 24rem; right: 50rem; }

    /* FOOTER */
    .footer__inner { margin: 0 50rem; }
    .footer__bottom { margin-top: 100rem; padding: 28rem 0 40rem; }

    .footer__logo svg { width: 200rem; height: auto; }

    .footer__menu-container .menu { gap: 36rem; }
    .footer__menu-container .menu > li > ul { margin-top: 10rem; }
    .footer__menu-container .menu > li > ul > li + li { margin-top: 8rem; }

    /* ERROR 404*/
    .error-404__inner { padding-top: 144rem; }

}



/* **************************************** *
 * 1200px
 * **************************************** */
@media (max-width: 1200px){

    html,
    html.safari.desktop { font-size: 0.0833333333333333vw; }
    
    /* VAR */
    :root {
        --font-size-primary-01: 54rem;
        --font-size-primary-02: 40rem;
        --font-size-primary-03: 32rem;
        --font-size-primary-04: 24rem;
        --font-size-primary-05: 22rem;

        --font-lineheight-primary-01: 68rem;
        --font-lineheight-primary-02: 50rem;
        --font-lineheight-primary-03: 42rem;
        --font-lineheight-primary-04: 36rem;
        --font-lineheight-primary-05: 33rem;
    }

    /* LAYOUT */
    .main-container { padding-top: 200rem; padding-bottom: 160rem; }

    .wrap { max-width: inherit; margin: 0 40rem; }
    .wrap-wide { margin: 0 40rem; }
    .wrap-moderate { margin: 0 40rem; }

    /* PAGE */
    .article__header { padding-bottom: 60rem; }
    .article__desc { margin-top: 20rem; }
    
    .article__visual-banner { border-radius: 24rem; }
    .article__visual-banner .article__visual-content { margin: 0 60rem; }
    .article__visual-content { margin-top: 60rem; }
    .article__visual-desc { margin-top: 28rem; }

    .article__section { padding: 140rem 0 160rem; }
    body:has(.jt-cta) .article__section:last-child { padding-bottom: 160rem; }
    .article__section-head { margin-bottom: 60rem; }
    .article__section-desc { margin-top: 28rem; }
    .article__section-desc p + p { margin-top: 20rem; }

    /* HEADER */
    #header { --header-height: 70rem; }
    .header__inner { margin: 0 40rem; height: var(--header-height); }

    #logo { width: 180rem; }

    .sticky-banner__content p { margin: 0 40rem; padding: 0 36rem; }
    .sticky-banner__close { right: 36rem; }

    .header__utils { right: 42rem; }
    .header__utils-list > li:nth-child(n+2) { display: none; }

    .menu-container { display: none; }

    .small-menu-controller { display: block; width: 30rem; height: 30rem; position: absolute; top: 50%; right: -3rem; translate: 0 -50%; }
    .small-menu-controller__line { display: block; width: 24rem; height: 2px; position: absolute; left: 3rem; background: var(--color-black); }
    .small-menu-controller__line--01 { top: 6rem; }
    .small-menu-controller__line--02 { top: 14rem; }
    .small-menu-controller__line--03 { top: 22rem; }

    .small-menu-container { display: none; width: 100%; height: 100%; padding-top: calc((var(--sticky-height, 0) * 1px) + var(--header-height)); position: fixed; top: 0; left: 0; background: var(--color-white); overflow: hidden; z-index: 650; }
    .small-menu-container:after { content: ''; position: absolute; left: 0; top: calc((var(--sticky-height, 0) * 1px) + (var(--header-height) - 1px)); width: 100%; height: 1px; background: var(--color-gray-400); }
    .small-menu-container__outer { display: flex; flex-direction: column; justify-content: space-between; height: 100%; z-index: 2; }
    .small-menu-container__inner { flex: 1; padding: 16rem 0; overflow-y: scroll; }
    .small-menu-container__contact { padding: 40rem; }
    .small-menu-container__contact > a { display: block; padding: 12rem 60rem; text-align: center; background: var(--color-primary); color: var(--color-white); border-radius: 99rem; }
    .small-menu-container__language { position: absolute; top: calc(var(--sticky-height, 0) * 1px); right: 90rem; height: var(--header-height); display: flex; align-items: center; gap: 18rem; }
    .small-menu-container__language > a { position: relative; color: var(--color-gray-500); }
    .small-menu-container__language > a.small-menu-container__language--current { color: var(--color-primary); }
    .small-menu-container__language > a + a:before { content: ''; position: absolute; top: calc(var(--font-lineheight-primary-08) / 2); left: -9rem; width: 2rem; height: 10rem; background: var(--color-gray-500); translate: -50% -5rem; }
    .small-menu-nav { display: block; }
    #small-menu { position: relative; }
    #small-menu li { display: block; position: relative; }
    #small-menu a { display: block; position: relative; padding-left: 40rem; padding-right: 40rem; transition: color .3s; }
    #small-menu > li > a { padding-top: 16rem; padding-bottom: 16rem; font-size: var(--font-size-primary-04); line-height: var(--font-lineheight-primary-04); font-weight: 700; letter-spacing: var(--letter-spacing); color: var(--color-black); }
    #small-menu > li > a > span { display: flex; align-items: center; gap: 4rem; }
    #small-menu > li.menu-item-has-children > a > span:after { content: ''; display: inline-block; width: 16rem; height: 16rem; background: no-repeat center center / cover; background-image: url(../images/icon/icon-menu-arrow.svg); transition: rotate .3s, background-image .3s; }
    #small-menu > li.current-menu-item.menu-item-has-children > a > span:after, 
    #small-menu > li.current-menu-ancestor.menu-item-has-children > a > span:after, 
    #small-menu > li:has(.current-menu-item) > a > span:after { background-image: url(../images/icon/icon-menu-arrow-active.svg); }
    #small-menu > li > ul { display: none; margin-bottom: 16rem; }
    #small-menu > li > ul > li > a { padding-top: 8rem; padding-bottom: 8rem; font-size: var(--font-size-primary-07); line-height: var(--font-lineheight-primary-07); font-weight: 700; letter-spacing: var(--letter-spacing); color: var(--color-gray-900); }
    #small-menu > li.current-menu-item > a, #small-menu > li.current-menu-ancestor > a, #small-menu > li:has(.current-menu-item) > a { color: var(--color-primary); }
    #small-menu > li.menu-item-has-children.menu-item--open > a > span:after { opacity: 1; rotate: -180deg; }
    #small-menu > li > ul > li.current-menu-item > a > span { text-decoration: underline; text-underline-offset: 5rem; text-decoration-thickness: 1rem; text-decoration-color: currentColor; }

    body.open-menu-fixed { width: 100%; height: 100%; top: 0; bottom: 0; left: 0; right: 0; overflow: hidden; }
    body.open-menu #header { transform: none !important; opacity: 1 !important; visibility: visible !important; }
    body.open-menu #logo, body.open-menu .small-menu-controller { z-index: 651; }

    .header__search-container { padding: 72rem 0; }
    .header__search-close { top: 20rem; right: 40rem; }

    /* FOOTER */
    .footer__inner { margin: 0 40rem; }
    .footer__top { gap: 80rem; justify-content: space-between; padding-top: 48rem; }
    .footer__top-left { display: none; }
    .footer__top-right { width: 100%; }
    .footer__bottom { margin-top: 80rem; padding: 24rem 0 36rem;  }

    .footer__logo svg { width: 180rem; }
    
    .footer__menu-container .menu { gap: 32rem; }
    .footer__menu-container .menu > li { flex: 1; width: auto; }

    /* ERROR 404*/
    .error-404__inner { padding-top: 122rem; }

}



/* **************************************** *
 * 1023px
 * **************************************** */
@media (max-width: 1023px){

    html,
    html.safari.desktop { font-size: 0.09775171065493645vw; }

    
    /* VAR */
    :root {
        --font-size-primary-01: 50rem;
        --font-size-primary-02: 38rem;
        --font-size-primary-03: 30rem;
        --font-size-primary-04: 22rem;
        --font-size-primary-05: 21rem;

        --font-lineheight-primary-01: 62rem;
        --font-lineheight-primary-02: 48rem;
        --font-lineheight-primary-03: 40rem;
        --font-lineheight-primary-04: 33rem;
        --font-lineheight-primary-05: 32rem;
    }
    
    /* LAYOUT */
    .main-container { padding-top: 180rem; padding-bottom: 140rem; }
    
    br.lgbr { display: block !important; }

    /* PAGE */
    .article__header { padding-bottom: 48rem; }
    .article__visual-banner:has(.article__visual-content) { aspect-ratio: auto; min-height: 320rem; }
    .article__visual-banner .article__visual-content { margin: 48rem; }
    .article__visual-content { margin-top: 48rem; }
    .article__section { padding: 120rem 0 140rem; }
    .article__section-head { margin-bottom: 48rem; }

    /* PRIVACY */
    .privacy__revision { margin-top: 32rem; }

}



/* **************************************** *
 * 860px
 * **************************************** */
@media (max-width: 860px){

    html,
    html.safari.desktop { font-size: 0.13020833333333335vw; }

    /* VAR */
    :root {
        --font-size-primary-01: 42rem;
        --font-size-primary-02: 36rem;
        --font-size-primary-04: 21rem;
        --font-size-primary-05: 20rem;
        --font-size-primary-06: 18rem;
        --font-size-primary-07: 16rem;
        --font-size-primary-08: 15rem;

        --font-lineheight-primary-01: 58rem;
        --font-lineheight-primary-02: 47rem;
        --font-lineheight-primary-04: 32rem;
        --font-lineheight-primary-05: 30rem;
        --font-lineheight-primary-06: 28rem;
        --font-lineheight-primary-07: 26rem;
        --font-lineheight-primary-08: 24rem;
    }

    /* LAYOUT */
    .main-container { padding-top: 160rem; padding-bottom: 120rem; }
    .wrap { margin: 0 24rem; }
    .wrap-wide { margin: 0 24rem; }
    .wrap-moderate { margin: 0 24rem; }
    .wrap-narrow { max-width: inherit; margin: 0 24rem; }
    
    br.lgbr { display: none !important; }
    br.mdbr { display: block !important; }

    /* PAGE */
    .article__header { padding-bottom: 40rem; }
    .article__desc { margin-top: 16rem; }

    .article__visual-banner { border-radius: 16rem; }
    .article__visual-banner .article__visual-content { margin: 40rem; }
    .article__visual-content { margin-top: 40rem; }
    .article__visual-desc { margin-top: 24rem; }
    .article__visual-desc br { display: none; }

    .article__section { padding: 100rem 0 120rem; }
    body:has(.jt-cta) .article__section:last-child { padding-bottom: 120rem; }
    .article__section-head { margin-bottom: 40rem; }
    .article__section-desc { margin-top: 24rem; }
    .article__section-desc br { display: none; }
    .article__section-desc p + p { margin-top: 16rem; }

    /* HEADER */
    #haeder { --header-height: 64rem }
    .header__inner { margin: 0 24rem; }

    #logo { width: 156rem; }

    .small-menu-container__inner { padding: 12rem 0; }
    .small-menu-container__contact { padding: 40rem 24rem; }
    .small-menu-container__language { right: 74rem; }

    #small-menu a { padding-left: 24rem; padding-right: 24rem; padding-top: 12rem; padding-bottom: 12rem; }
    #small-menu > li > ul > li > a { padding-top: 4rem; padding-bottom: 4rem; }
    #small-menu > li > ul > li:first-child > a { padding-top: 0; }
    #small-menu > li > ul > li:last-child > a { padding-bottom: 0; }

    .header__utils { right: 34rem; }

    .header__search-container { padding: 64rem 0; }
    .header__search-close { top: 16rem; right: 24rem; }

    .sticky-banner__content { padding: 8rem 0; }
    .sticky-banner__content p { margin: 0 24rem; padding: 0 32rem; }
    .sticky-banner__close { right: 20rem; }

    /* FOOTER */
    .footer__inner { margin: 0 24rem; }
    .footer__top { padding-top: 44rem; }
    .footer__bottom { margin-top: 60rem; flex-direction: column; gap: 12rem; padding-top: 0; }
    .footer__bottom:before { display: none; }
    .footer__bottom-left { flex-direction: column; gap: 12rem; order: 2; }
    .footer__bottom-right { order: 1; }

    .footer__link { order: 1; }
    .footer__copyright { order: 2; }

    .footer__menu-container .menu { flex-direction: column; gap: 0; }
    .footer__menu-container .menu > li { border-bottom: 1px solid var(--color-gray-400); }
    .footer__menu-container .menu > li > a { display: block; padding: 16rem 0; }
    .footer__menu-container .menu > li > a:after { display: none; }
    .footer__menu-container .menu > li > a > span { display: flex; justify-content: space-between; align-items: center; }
    .footer__menu-container .menu > li.menu-item-has-children > a > span:after { content: ''; display: inline-block; position: relative; right: -2rem; width: 16rem; height: 16rem; background: no-repeat center center / cover; background-image: url(../images/icon/icon-menu-arrow.svg); transition: rotate .3s, background-image .3s; }
    .footer__menu-container .menu > li.menu-item--open > a > span:after { rotate: -180deg }
    .footer__menu-container .menu > li > ul { display: none; background: var(--color-white); border-radius: 8rem; margin-top: 0; margin-bottom: 16rem; }
    .footer__menu-container .menu > li > ul > li + li { margin-top: 0; }
    .footer__menu-container .menu > li > ul > li > a { width: 100%; padding: 4rem 24rem; }
    .footer__menu-container .menu > li > ul > li > a:after { display: none; }
    .footer__menu-container .menu > li > ul > li > a > span { font-size: var(--font-size-primary-07); line-height: var(--font-lineheight-primary-07); }
    .footer__menu-container .menu > li > ul > li:first-child > a { padding-top: 20rem; }
    .footer__menu-container .menu > li > ul > li:last-child > a { padding-bottom: 20rem; }
    .footer__menu-container .menu > li > ul > li.current-menu-item > a { color: var(--color-black); }
    .footer__menu-container .menu > li > ul > li.current-menu-item > a > span { text-decoration: underline; text-underline-offset: 5rem; text-decoration-thickness: 1px; }

    /* PRIVACY */
    .privacy__revision { margin-top: 24rem; }
    .privacy__revision-choice { min-width: 180rem; }

    /* ERROR 404 */
    .error-404__inner { padding-top: 110rem; }
    .error-404__motion { width: 240rem; margin-bottom: 32rem; }
    .error-404__content p { margin-top: 12rem; }
    .error-404__copyright { padding: 32rem 0; }

}



/* **************************************** *
 * 540px
 * **************************************** */
@media (max-width: 540px){

    html,
    html.safari.desktop { font-size: 0.2564102564102564vw; }

    /* VAR */
    :root {
        --font-size-primary-01: 36rem;
        --font-size-primary-02: 32rem;
        --font-size-primary-03: 28rem;
        --font-size-primary-04: 20rem;
        --font-size-primary-05: 18rem;
        --font-size-primary-06: 16rem;
        --font-size-primary-07: 15rem;
        --font-size-primary-08: 14rem;
        --font-size-primary-09: 13rem;

        --font-lineheight-primary-01: 48rem;
        --font-lineheight-primary-02: 46rem;
        --font-lineheight-primary-03: 40rem;
        --font-lineheight-primary-04: 32rem;
        --font-lineheight-primary-05: 28rem;
        --font-lineheight-primary-06: 24rem;
        --font-lineheight-primary-07: 24rem;
        --font-lineheight-primary-09: 20rem;
    }

    /* LAYOUT */
    .main-container { padding-top: 144rem; padding-bottom: 100rem; }
    .wrap { margin: 0 20rem; }
    .wrap-wide { margin: 0 20rem; }
    .wrap-moderate { margin: 0 20rem; }
    .wrap-narrow { margin: 0 20rem; }

    br.mdbr { display: none !important; }
    br.smbr { display: block !important; }

    /* PAGE */
    .article__header { padding-bottom: 32rem; }
    .article__desc { margin-top: 12rem; }
    .article__visual-bg--desktop { display: none; }
    .article__visual-bg--mobile { display: block; }

    .article__visual-banner { aspect-ratio: 1 / 1.5; }
    .article__visual-banner .article__visual-title { font-size: var(--font-size-primary-03); line-height: var(--font-lineheight-primary-03); }
    .article__visual-banner .article__visual-content { margin: 36rem 24rem; }
    .article__visual-content { margin-top: 32rem; }
    .article__visual-title br { display: none; }

    .article__section { padding: 80rem 0 100rem; }
    body:has(.jt-cta) .article__section:last-child { padding-bottom: 100rem; }
    .article__section-head { margin-bottom: 36rem; }
    .article__section-title br { display: none; }
    .article__section-desc p + p { margin-top: 12rem; }

    /* HEADER */
    #header { --header-height: 64rem; }
    .header__inner { margin: 0 20rem; }

    .small-menu-container__contact { padding: 40rem 20rem; }
    .small-menu-container__language { right: 64rem; }

    #small-menu > li > a { padding-top: 15rem; padding-bottom: 15rem; }
    #small-menu > li > ul { margin-bottom: 15rem; }
    #small-menu > li > ul > li > a { padding-top: 6rem; padding-bottom: 6rem; }

    .header__search-container { padding: 54rem 0; }
    .header__search-close { right: 20rem; }
    .header__search-close .jt-icon { width: 24rem; height: 24rem; }

    .sticky-banner__content p { margin: 0 20rem; padding: 0 28rem; }
    .sticky-banner__close { right: 16rem; }

    /* FOOTER */
    .footer__inner { margin: 0 20rem; }
    .footer__bottom { gap: 8rem; }
    .footer__bottom-left { gap: 8rem; }

    .footer__menu-container .menu > li > ul > li > a { padding: 4rem 16rem; }
    .footer__menu-container .menu > li > ul > li:first-child > a { padding-top: 16rem; }
    .footer__menu-container .menu > li > ul > li:last-child > a { padding-bottom: 16rem; }
    .footer__menu-container .menu > li.menu-item-has-children > a > span:after { width: 14rem; height: 14rem; }

    .footer__link { gap: 8rem; }

    /* PRIVACY */
    .privacy__revision-choice { min-width: 160rem; }

    /* ERROR 404 */
    .error-404__inner { padding-top: 104rem; }
    .error-404__motion { width: 200rem; margin-bottom: 24rem; }
    .error-404__content br { display: none; }
    .error-404__copyright { padding: 24rem 0; }

}