@charset "utf=8";

/* ==========================================
ヘッダー
========================================== */

#clone {
    display: none;
}

.header {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: auto;
    max-width: 192rem;
    width: 100%;
    padding: 0 1.5rem;
    z-index: 99;
    transition: all .3s;
}

.header-frame {
    width: 100%;
    padding: 0 1.5rem;
}

.header-row {
    max-width: 182rem;
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.header-logo-link {
    display: block;
}

.index-header-logo {
    display: block;
}

.header-logo {
    display: none;
}

.header-right {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    max-width: 150rem;
    width: 85%;
}

.header-frame {
    padding: 3.5rem 0 0;
}

.header-logo-link {
    max-width: 300px;
    width: 20%;
}

.drop-menu-block:hover {
    background: var(--white);
    color: var(--black01);
    transition: all .3s;
}

.drop-menu-block {
    border: 1px solid var(--white);
    color: var(--white);
    transition: all .3s;
}

.language-box {
    border: 1px solid var(--white);
}

.arrow-box {
    background: url(../../../../uploads/btn_arrow_down_white.svg) no-repeat center;
    background-size: 100%;
}

.drop-menu-block:hover .arrow-box {
    background: url(../../../../uploads/btn_arrow_top_black.svg) no-repeat center;
    background-size: 100%;
    transform: rotate(180deg);
}

.drop-menu-block .rotate.arrow-box {
    background: url(../../../../uploads/btn_arrow_down_white.svg) no-repeat center;
    background-size: 100%;
    transform: rotate(180deg);
}

.drop-menu-block:hover .rotate.arrow-box {
    background: url(../../../../uploads/btn_arrow_top_black.svg) no-repeat center;
    background-size: 100%;
    transform: rotate(0deg);
}

.global-navi-menu-link {
    border-bottom: 1px solid var(--white);
    color: var(--white);
}

/*============ navi ============*/

.header-navi-block {
    display: none;
    /* max-width: 120.5rem; */
    /* width: 85%; */
    flex: 1;
    margin: 0 3rem 0 0;
}

.header-navi-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-navi-left {
    display: flex;
    justify-content: space-between;
    flex: 1;
}

.header-navi-right {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 55.3rem;
    width: 45.89%;
    margin: 0 0 0 3rem;
}

.header-navi-link {
    flex: 1;
    position: relative;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.15em;
    text-align: center;
    padding: 0 0 .2rem 0;
}

.header-navi-link > a {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    justify-content: flex-end;
    align-items: center;
    padding: 0 1rem;
}

.header-navi-link-small > a {
    display: block;
}

.ko-KR .header-navi-link {
    font-size: 1.7rem;
}

.header-navi-link a span {
    display: inline-flex;
    font-size: 1.4rem;
}

.header-navi-link:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    margin: auto;
    width: 0.1rem;
    height: 2.5rem;
    background: var(
    --black01);
    z-index: 10;
}

.header-navi-link.white {
    color: var(--black01);
}

.header-navi-link-small {
    font-size: 1.6rem;
}

.header-navi-ec-link {
    max-width: 26rem;
    width: 49%;
    height: 6rem;
    font-size: 2rem;
}

.header-navi-btob-link {
    max-width: 30rem;
    width: 49%;
}

.header-navi-right .btob-link-color {
    color: var(--white);
    border: 0px solid var(--white);
    background: var(--black01);
    transition: all .3s;
}

.header-navi-right .btob-link-color:hover {
    background: var(--quaternary);
    transition: all .3s;
}

/*========= ドロップダウン ===============*/

.dropdown-toggle::after {
    display: none;
}

.drop-menu-block {
    max-width: 20rem;
    width: 20%;
    height: 45px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    padding: .5rem 2rem .5rem 2.5rem;
    margin: 1.5rem 0 0;
    /* cursor: pointer; */
}

.language-text {
    font-family: var(--font-family01);
    font-weight: 400;
    font-size: 1.8rem;
    letter-spacing: 0.03em;
    line-height: 1.45em;
}

.hPcWorldIcon {
    width: 100%;
}

.global-navi-box {
    display: none;
    width: 100%;
    position: absolute;
    padding: .5rem 0 0;
    margin: auto;
    top: 100%;
    right: 0px;
}

.drop-menu-block:hover > #drop01 {
    display: block;
}

.drop-menu-block .arrow-box {
    width: 1.5rem;
    height: .9rem;
    display: block;
    margin: 0 0 0 auto;
}

.global-navi-menu-link {
    padding: .8rem;
    display: block;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
    font-weight: bold;
}

.language-box .global-navi-menu-link:last-child {
    border-bottom: 0 solid;
}

.global-navi-menu-link:hover {
    text-decoration: underline;
}

#drop01 {
    display: none;
    transition: all 0.3s ease;
}

#drop01.open {
    display: block;
}

/*============ bogo ============*/

.bogoflags {
    display: none !important;
}

.global-navi-box .current {
    color: var(--white);
}

.global-navi-box .bogo-language-name {
    color: var(--white);
}

.global-navi-box .bogo-language-switcher li {
    padding: .8rem 1.5rem !important;
    text-align: center;
    border-bottom: 1px solid var(--white);
}

.global-navi-box .bogo-language-switcher li a {
    display: block;
    width: 100%;
    text-align: center;
}

.global-navi-box .bogo-language-switcher li a:hover {
    text-decoration: underline;
}

.global-navi-box .bogo-language-switcher li .current {
    text-decoration: underline;
}

.bogo-language-switcher {
    display: flex;
    flex-direction: column;
}

.bogo-language-switcher .en-US {
	order: 1;
}

.bogo-language-switcher .zh-CN {
	order: 2;
}

.bogo-language-switcher .ko-KR {
	order: 3;
}

.bogo-language-switcher .ja {
	order: 4;
	border: 0 !important;
}

/*============ 翻訳切替 ============*/

.en-US .en-link, 
.ko-KR .en-link,
.zh-CN .ec-link {
    display: flex;
}

.ja .en-link {
    display: none;
}

.en-US .jp-link,
.ko-KR .jp-link,
.zh-CN .jp-link {
    display: none;
}

.ja .jp-link {
    display: flex;
}

/*========= is-animation ===============*/

.header.is-animation {
    position: fixed;
    background: var(--white);
    transition: all .3s;
}

.is-animation .header-frame {
    padding: .8rem 0 .7rem;
}

.is-animation .header-row {
    align-items: center;
}

.is-animation .header-logo-link {
    width: 10.35%;
}

.is-animation .header-navi-block {
    display: block;
}

.is-animation .index-header-logo {
    display: none;
}

.is-animation .header-logo {
    display: block;
}

.is-animation .drop-menu-block {
    margin: 0;
    border: .1rem solid var(--black01);
    color: var(--black01);
    transition: all .3s;
}

.is-animation .drop-menu-block .arrow-box {
    background: url(../../../../uploads/btn_arrow_top_black.svg) no-repeat center;
    transform: rotate(180deg);
    background-size: 100%;
}

.is-animation .drop-menu-block:hover .arrow-box {
    transform: rotate(180deg);
}

.is-animation .drop-menu-block .rotate.arrow-box {
    background: url(../../../../uploads/btn_arrow_top_black.svg) no-repeat center;
    transform: rotate(0deg);
    background-size: 100%;
}


.is-animation .language-box {
    border: .1rem solid var(--black01);
}

.is-animation .global-navi-box .current {
    color: var(--black01);
}

.is-animation .global-navi-box .bogo-language-name {
    color: var(--black01);
}

.is-animation .global-navi-box .bogo-language-switcher li {
    border-bottom: .1rem solid var(--black01);
    background: var(--white);
}

/*========= モーダル表示のためのCSS ===============*/

/*全て共通：hideエリアをはじめは非表示*/

/* .popup-iframe {
    display: none;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: var(--primary);
    color: var(--white);
    max-width: 20rem;
    width: 100%;
    border-radius: 1rem;
    margin: 0 10rem 0 0;
    padding: 1rem 1.5rem;
    font-size: 1.8rem;
    font-weight: 500;
}

.hide-area{
    display: none;
}

.modaal-content-container .header-tel-btn{
    margin: 0 auto;
} */

/*全て共通：モーダルのボタンの色を変更したい場合*/
/* .modaal-close:after, 
.modaal-close:before{
    background:#ccc;  
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
    background:#666;
}

.modaal-close {
    right: 30px;
    top: 140px;
} */

/*========= ヘッダー ===============*/

/* .header {
    max-width: 1920px;
    width: 100%;
    position: relative;
    padding: 0 1.5rem;
    transition: all .3s;
}

.header-right {
    display: flex;
    justify-content: flex-end;
    max-width: 140rem;
    width: 85%;
}

.header-row {
    max-width: 175.8rem;
    width: 100%;
    margin: 0 auto;
    padding: 1.7rem 0 1.4rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-logo {
    max-width: 23.2rem;
    width: 20%;
}

.header-logo-scroll { 
    display: none;
    max-width: 18.9rem;
    width: 20%; 
}

.header-logo-link {
    display: block;
}

.header-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.header-nav-link {
    display: block;
    margin: 0 7.5rem 0 0;
    text-align: center;
}

.header-nav-color {
    color: var(--primary);
}

.header-nav-link, .header-nav-link:hover,
.header-nav-link .header-nav-jp,
.header-nav-link:hover .header-nav-jp,
.header-nav-link .header-nav-en,
.header-nav-link:hover .header-nav-en
{
    transition: all .3s;
}

.header-nav-jp {
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    margin: .6rem 0 0;
}

.header-nav-en {
    font-family: var(--font-family01);
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.header-nav-link:hover .header-nav-jp {
    text-decoration: underline;
}

.header-tel-btn {
    max-width: 35.2rem;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 6.1rem 0 0;
    position: relative;
}

.header-tel-main.bg-secondary {
    background: var(--secondary);
}

.header-tel-main.white {
    color: var(--white);
} */

/* .header-tel-main {
    position: relative;
    max-width: 35.12em;
    width: 100%;
    padding: 2.4rem 1.5rem 1.2rem 3.2rem;
    border-radius: 1rem;
    margin: -1.1rem 0 .5rem 0; 
    z-index: -1;
} */

/* .header-tel-main .tel-icon {
    margin: 0 1rem 0 0;
}

.tel-icon {
    display: block;   
}

.tel-icon-scroll {
    display: none;   
}


.header-tel-color {
    color: var(--white);
}

.header-tel-bg-color {
    background: var(--secondary);
}

.header-tel-fukidashi {
    position: absolute; 
    top: 0;
    border-radius: 1rem;
    max-width: 32.3rem;
    width: 91.76%;
    padding: .9rem 1.5rem 1.3rem;
    box-shadow: 0px -1px 5px 0px rgba(0, 0, 0, 0.15);
    z-index: 10;
}

.header-tel-fukidashi::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    border-style: solid;
    border-width: 9px 8px 0 8px;
    border-color: #fff transparent transparent;
    translate: -50% 100%;
  }

.header-tel-fukidashi-text {
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    line-height: 1.45em;
}

.header-tel-fukidashi-text.primary {
    color: var(--primary);
}

.tel-btn-attention-row {
    display: flex;
    align-items: flex-start;
}

.tel-btn-attention-text {
    font-size: 1.4rem;
    font-weight: 400;
} */

/* ==========================================
追従
========================================== */

/* .header.is-animation {
    position: fixed;
    transition: all .3s;
}

.is-animation .popup-iframe { 
    border: .1rem solid var(--white);   
}

.header-bg-color.is-animation {
    background: var(--secondary);
}

.is-animation .header-logo { 
    display: none;   
}

.is-animation .header-logo-scroll { 
    display: block;   
}

.is-animation .header-nav-en { 
    display: none;   
}

.is-animation .header-nav-color {
    color: var(--white);
}

.is-animation .header-tel-btn {
    padding: 0;
}

.is-animation .header-tel-main {
    margin: 0 0 .5rem 0;
}

.is-animation .tel-icon {
    display: none;   
}

.is-animation .tel-icon-scroll {
    display: block;   
}

.is-animation .header-tel-color {
    color: var(--secondary);
}

.is-animation .header-tel-main {
    padding: 1.2rem 1.5rem 1.2rem 3.2rem;
}

.is-animation .header-tel-bg-color {
    background: var(--white);
}

.is-animation .header-tel-fukidashi { 
    display: none;   
}

.is-animation .tel-btn-attention-row { 
    display: none;   
} */

/* --- 言語切替 --- */

.header-logo-link.en, .header-logo-link.ko, .header-logo-link.zh {
    display: none;
}

.en-US .header-logo-link.ja {
    display: none;
}

.en-US .header-logo-link.en {
    display: block;
}

.ko-KR .header-logo-link.ja {
    display: none;
}

.ko-KR .header-logo-link.ko {
    display: block;
}

.zh-CN .header-logo-link.ja {
    display: none;
}

.zh-CN .header-logo-link.zh {
    display: block;
}

.header-navi-link.en, .header-navi-link.ko, .header-navi-link.zh {
    display: none;
}

.en-US .header-navi-link.ja {
    display: none;
}

.en-US .header-navi-link.en {
    display: block;
}

.ko-KR .header-navi-link.ja {
    display: none;
}

.ko-KR .header-navi-link.ko {
    display: block;
}

.zh-CN .header-navi-link.ja {
    display: none;
}

.zh-CN .header-navi-link.zh {
    display: block;
}

.sp-nav-list-item.en, .sp-nav-list-item.ko, .sp-nav-list-item.zh {
    display: none;
}

.en-US .sp-nav-list-item.ja {
    display: none;
}

.en-US .sp-nav-list-item.en {
    display: block;
}

.ko-KR .sp-nav-list-item.ja {
    display: none;
}

.ko-KR .sp-nav-list-item.ko {
    display: block;
}

.zh-CN .sp-nav-list-item.ja {
    display: none;
}

.zh-CN .sp-nav-list-item.zh {
    display: block;
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1920px) {



}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1550px) {

    .header-navi-block {
        margin: 0 1.6rem 0 0;
    }

    .header-navi-link {
        width: 11rem;
        font-size: 1.6rem;
    }

    .ko-KR .header-navi-link {
        font-size: 1.5rem;
    }

    .header-navi-ec-link {
        font-size: 1.8rem;
    }

    .header-navi-btob-link {
        font-size: 1.6rem;
    }
}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1024px) {

    .header-frame {
        padding: 2rem 0 0;
    }

    .ko-KR .header-navi-link {
        font-size: 1.4rem;
    }

    .drop-menu-block {
        margin: 0 10rem 0 0;
    }

    .drop-menu-block {
        width: 30%;
    }

    .ham-language-box .bogo-language-switcher {
        display: flex;
        align-items: center;
        justify-content: space-between;
        color: var(--black01);
        width: 80%;
        margin: 0 auto;
    }

    .header.is-animation {
        height: 7.5rem;
    }

    .is-animation .header-frame {
        padding: .8rem 0;
    }

    .is-animation .header-navi-block {
        display: none;
    }

    .is-animation .header-logo-link {
        width: 15%;
    }

    .is-animation .drop-menu-block {
        margin: 0 10rem 0 0;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 768px) {

    .is-animation .header-frame {
        padding: .4rem 0;
    }

    .is-animation .header-logo-link {
        width: 25%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 576px) {

    .header-frame {
        padding: 1rem 0;
    }

    .header-logo-link {
        width: 28%;
    }

	.drop-menu-block {
		max-width: 200px;
		width: 50%;
		margin: 0 6rem 0 0px;
	}

	.is-animation .drop-menu-block {
		margin: 0 6rem 0 0px;
	}

    .language-text {
        font-size: 1.5rem;
    }

    .header.is-animation {
        height: 6rem;
    }

    .is-animation .header-frame {
        padding: .5rem 0;
    }

    .is-animation .header-logo-link {
        width: 36%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 414px) {

    .header-logo-link {
        width: 36%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */