.tab-panel iframe,.blog-article iframe,.video iframe{width: 100%;height: auto !important;aspect-ratio: 16 / 9;}
.df{display: flex;}
.f_w,.fw{flex-wrap: wrap;}
.a_c{align-items: center;}
.j_c{justify-content: center;}
.j_b{justify-content: space-between;}
.j_a{justify-content: space-around;}
.fd_rr{
    flex-direction: row-reverse;
}
.t_l{text-align: left;}
.t_c{text-align: center;}
.t_r{text-align: right;}
.ttu{text-transform: uppercase;}
.p_r{position: relative;}
.p_a100{position: absolute;z-index: 1;display: block;width: 100%;left: 0;right: 0;top: 0;bottom: 0;}
.oh1{display: -webkit-box;-webkit-line-clamp: 1;-webkit-box-orient: vertical;overflow: hidden;}
.oh2{-webkit-line-clamp: 2;}
.oh3{-webkit-line-clamp: 3;}
.oh4{-webkit-line-clamp: 4;}
.inquiry-pop-bd {position:fixed;left:0;top:0;width:100%;height:100% !important;background:rgba(0,0,0,.7);display:none;overflow:hidden;z-index:20000;}
.inquiry-pop-bd .inquiry-pop {position:relative;width:500px;background:#FFF;margin:150px auto;padding:30px;box-shadow:0 0 10px rgba(255,255,255,.5);}
.inquiry-pop-bd .inquiry-pop .ico-close-pop {position:absolute;right:-10px;top:-10px;width:30px;height:30px;background:url(/themes/template/static/images/fancy_close.png) no-repeat center center;cursor:pointer;z-index:1;}
.mauticform_wrapper {position:relative;margin-top:45px;}
.mauticform_wrapper {max-width:100% !important;padding:0px!important;margin:0 !important;}
iframe {box-shadow:0 0 10px rgb(0 0 0 / 10%);width:100%;height:100%;border:0;}
@media screen and (max-width:600px){
    .inquiry-pop-bd .inquiry-pop{width: auto;}
    .inquiry-pop-bd .inquiry-pop .ico-close-pop{
        right: 0;
        top: 0;
    }
}

:root{
    --c1:#031663;
    --c2:#333333;
    --c3:#959595;
    --c4:#383838;
    --c5:#3e3e3e;
    --c6:#424242;
    --c7:#0C2893;
    --c8:#1960D8;
    --c9:#6e6e6e;
}
a,a:hover{
    color: var(--c2);
    transition: .3s;
}
.nbox{
    position: relative;
    width: 100%;
    overflow: hidden;
    font-family: sans-serif;
    background: #fff;
}
.c0{
    color: #000;
}
.c1{
    color: var(--c1);
}
.c2{
    color: var(--c2);
}
.c3{
    color: var(--c3);
}
.c4{
    color: var(--c4);
}
.c5{
    color: var(--c5);
}
.c6{
    color: var(--c6);
}
.c7{
    color: var(--c7);
}
.c8{
    color: var(--c8);
}
.c9{
    color: var(--c9);
}
.cb{
    color: #fff;
}
.hc1:hover{
    color: var(--c1) !important;
    transition: .3s;
}
.oh{
    overflow: hidden;
}
.h100{
    height: 100%;
}
.dn{
    display: none;
}
.a_s{align-items: flex-start;}
.a_e{align-items: flex-end;}
.j_e{
    justify-content: flex-end;
}
.tdu{
    text-decoration-line: underline;
}
.lh1{
    line-height: 1;
}
.lh11{
    line-height: 1.1;
}
.lh12{
    line-height: 1.2;
}
.lh13{
    line-height: 1.3;
}
.lh14{
    line-height: 1.4;
}
.lh15{
    line-height: 1.5;
}
.lh16{
    line-height: 1.6;
}
.lh17{
    line-height: 1.7;
}
.lh18{
    line-height: 1.8;
}
.lh19{
    line-height: 1.9;
}
.lh2{
    line-height: 2;
}
.fs12{
    font-size: 12px;
}
.fs13{
    font-size: 13px;
}
.fs14{
    font-size: 14px;
}
.fs15{
    font-size: 15px;
}
.fs16{
    font-size: 16px;
}
.fs17{
    font-size: 17px;
}
.fs18{
    font-size: 18px;
}
.fs19{
    font-size: 19px;
}
.fs20{
    font-size: 20px;
}
.fs22{
    font-size: 22px;
}
.fs23{
    font-size: 23px;
}
.fs24{
    font-size: 24px;
}
.fs25{
    font-size: 25px;
}
.fs26{
    font-size: 26px;
}
.fs28{
    font-size: 28px;
}
.fs30{
    font-size: 30px;
}
.fs32{
    font-size: 32px;
}
.fs34{
    font-size: 34px;
}
.fs35{
    font-size: 35px;
}
.fs36{
    font-size: 36px;
}
.fs40{
    font-size: 40px;
}
.fs46{
    font-size: 46px;
}
.fs48{
    font-size: 48px;
}
.fs50{
    font-size: 50px;
}
.fs54{
    font-size: 54px;
}
.fs55{
    font-size: 55px;
}
.fs58{
    font-size: 58px;
}
.fs60{
    font-size: 60px;
}
.fs70{
    font-size: 70px;
}
.fw100{
    font-weight: 100;
}
.fw200{
    font-weight: 200;
}
.fw300{
    font-weight: 300;
}
.fw400{
    font-weight: 400;
}
.fw500{
    font-weight: 500;
}
.fw600{
    font-weight: 600;
}
.fw700{
    font-weight: 700;
}
.fw800{
    font-weight: 800;
}
.fw900{
    font-weight: 900;
}
.w20{
    width: 20%;
}
.w25{
    width: 25%;
}
.w33{
    width: 33.3%;
}
.w50{
    width: 50%;
}
.w75{
    width: 75%;
}
.w100{
    width: 100%;
}
.mw730{
    width: 100%;
    max-width: 750px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw950{
    width: 100%;
    max-width: 970px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw980{
    width: 100%;
    max-width: 1000px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw1100{
    width: 100%;
    max-width: 1120px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw1200{
    width: 100%;
    max-width: 1220px;
    padding: 0 20px;
    margin: 0 auto;
}
.mw1240{
    width: 100%;
    max-width: 1260px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw1400{
    width: 100%;
    max-width: 1500px;
    padding: 0 50px;
    margin: 0 auto;
}
.mw1500{
    width: 100%;
    max-width: 1560px;
    padding: 0 30px;
    margin: 0 auto;
}
.mw1580{
    width: 100%;
    max-width: 1600px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw1600{
    width: 100%;
    max-width: 1700px;
    padding: 0 50px;
    margin: 0 auto;
}
.mw1680{
    width: 100%;
    max-width: 1700px;
    padding: 0 10px;
    margin: 0 auto;
}
.mw1700{
    width: 100%;
    max-width: 1760px;
    padding: 0 30px;
    margin: 0 auto;
}
.plr10{
    padding-left: 10px;
    padding-right: 10px;
}
.mt30{
    margin-top: 30px;
}
.mt20{
    margin-top: 20px;
}
.mt10{
    margin-top: 10px;
}
.p10{
    padding: 10px;
}
.pt10{
    padding-top: 10px;
}
.pt15{
    padding-top: 15px;
}
.pt20{
    padding-top: 20px;
}
.pt30{
    padding-top: 30px;
}
.pt40{
    padding-top: 40px;
}
.pt45{
    padding-top: 45px;
}
.pt50{
    padding-top: 50px;
}
.pt60{
    padding-top: 60px;
}
.pt70{
    padding-top: 70px;
}
.pt80{
    padding-top: 80px;
}
.pt90{
    padding-top: 90px;
}
.pt100{
    padding-top: 100px;
}
.pt110{
    padding-top: 110px;
}
.pt120{
    padding-top: 120px;
}
.pt130{
    padding-top: 130px;
}
.pt140{
    padding-top: 140px;
}
.pt150{
    padding-top: 150px;
}
.ci100{
    position: relative;
}
.ci100>img{
    width: 100%;
}
.ci100>a{
    position: absolute;
    z-index: 2;
    display: block;
    width: 100%;
    height: 100%;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
.ci100>a.df{
    display: flex;
}
.ci100h{
    overflow: hidden;
}
.ci100h>img{
    transition: .3s;
}
.ci100h:hover>img{
    transform: scale(1.1);
}
.br5{
    border-radius: 5px;
}
.br10{
    border-radius: 10px;
}
.br20{
    border-radius: 20px;
}
.language-flag a{position:relative;overflow: hidden;display: flex;align-items: center;}
.language-flag span {position: relative;display: inline-block;vertical-align: top;white-space: nowrap;padding: 0;overflow: hidden;text-align:left}
.language .change-language-cont{display:block;position:absolute;top:100%;right:0;left:auto;width:360px;background:#FFF;transform:scale3d(0.9, 0.9, 1);opacity:0;visibility:hidden;z-index:999;-moz-transition:all 0.3s ease-in-out;-webkit-transition:all 0.3s ease-in-out;-ms-transition:all 0.3s ease-in-out;-o-transition:all 0.3s ease-in-out;transition:all 0.3s ease-in-out;border-radius:5px;overflow-y:scroll;max-height:40vh;}
.language:hover .change-language-cont{transform:scale3d(1, 1, 1);opacity:1;visibility:visible;}
.language .change-language-cont ul{line-height: 1.5;}
.language .change-language-cont li{display:inline-block;vertical-align:top;width:30%;margin:0 0 10px;font-size:13px;overflow:hidden;padding:0;}
.language .change-language-cont li a:hover{color:#4e4e4e;}
.lang-none {padding:20px 10px 20px 20px;}
.lang-none li{width: 32%;padding:0;}
.language-flag .country-flag {position: relative;display: inline-block;margin: 0 5px 0;width: 22px;height: 16px;background-image: url(/themes/template/static/images/lang.gif);background-repeat: no-repeat;vertical-align: top;}
li.language-flag a {position: relative;display: flex !important;}
li.language-flag a span{width: calc(100% - 32px);}
.language-flag-af .country-flag {background-position: 0 0 !important;}
.language-flag-sq .country-flag {background-position: 0 -16px !important;}
.language-flag-ar .country-flag {background-position: 0 -32px !important;}
.language-flag-hy .country-flag {background-position: 0 -48px !important;}
.language-flag-az .country-flag {background-position: 0 -64px !important;}
.language-flag-eu .country-flag {background-position: 0 -80px !important;}
.language-flag-be .country-flag {background-position: 0 -96px !important;}
.language-flag-bg .country-flag {background-position: 0 -112px !important;}
.language-flag-ca .country-flag {background-position: 0 -128px !important;}
.language-flag-zh .country-flag {background-position: 0 -144px !important;}
.language-flag-zh-TW .country-flag {background-position: 0 -160px !important;}
.language-flag-hr .country-flag {background-position: 0 -176px !important;}
.language-flag-cs .country-flag {background-position: 0 -192px !important;}
.language-flag-da .country-flag {background-position: 0 -208px !important;}
.language-flag-nl .country-flag {background-position: 0 -240px !important;}
.language-flag-en .country-flag {background-position: 0 -256px !important;}
.language-flag-et .country-flag {background-position: 0 -272px !important;}
.language-flag-tl .country-flag {background-position: 0 -288px !important;}
.language-flag-fi .country-flag {background-position: 0 -304px !important;}
.language-flag-fr .country-flag {background-position: 0 -320px !important;}
.language-flag-gl .country-flag {background-position: 0 -336px !important;}
.language-flag-ka .country-flag {background-position: 0 -352px !important;}
.language-flag-de .country-flag {background-position: 0 -368px !important;}
.language-flag-el .country-flag {background-position: 0 -384px !important;}
.language-flag-ht .country-flag {background-position: 0 -400px !important;}
.language-flag-iw .country-flag {background-position: 0 -416px !important;}
.language-flag-hi .country-flag,
.language-flag-te .country-flag,
.language-flag-kn .country-flag,
.language-flag-ta .country-flag,
.language-flag-gu .country-flag {background-position: 0 -432px !important;}
.language-flag-hu .country-flag {background-position: 0 -448px !important;}
.language-flag-is .country-flag {background-position: 0 -464px !important;}
.language-flag-id .country-flag {background-position: 0 -480px !important;}
.language-flag-ga .country-flag {background-position: 0 -496px !important;}
.language-flag-it .country-flag {background-position: 0 -512px !important;}
.language-flag-ja .country-flag {background-position: 0 -528px !important;}
.language-flag-ko .country-flag {background-position: 0 -544px !important;}
.language-flag-la .country-flag {background-position: 0 -560px !important;}
.language-flag-lv .country-flag {background-position: 0 -576px !important;}
.language-flag-lt .country-flag {background-position: 0 -592px !important;}
.language-flag-mk .country-flag {background-position: 0 -608px !important;}
.language-flag-ms .country-flag {background-position: 0 -624px !important;}
.language-flag-mt .country-flag {background-position: 0 -640px !important;}
.language-flag-no .country-flag {background-position: 0 -656px !important;}
.language-flag-fa .country-flag {background-position: 0 -672px !important;}
.language-flag-pl .country-flag {background-position: 0 -688px !important;}
.language-flag-pt .country-flag {background-position: 0 -704px !important;}
.language-flag-ro .country-flag {background-position: 0 -720px !important;}
.language-flag-ru .country-flag {background-position: 0 -736px !important;}
.language-flag-sr .country-flag {background-position: 0 -752px !important;}
.language-flag-sk .country-flag {background-position: 0 -768px !important;}
.language-flag-sl .country-flag {background-position: 0 -784px !important;}
.language-flag-es .country-flag {background-position: 0 -800px !important;}
.language-flag-sw .country-flag {background-position: 0 -816px !important;}
.language-flag-sv .country-flag {background-position: 0 -832px !important;}
.language-flag-th .country-flag {background-position: 0 -848px !important;}
.language-flag-tr .country-flag {background-position: 0 -864px !important;}
.language-flag-uk .country-flag {background-position: 0 -880px !important;}
.language-flag-ur .country-flag {background-position: 0 -896px !important;}
.language-flag-vi .country-flag {background-position: 0 -912px !important;}
.language-flag-cy .country-flag {background-position: 0 -928px !important;}
.language-flag-yi .country-flag {background-position: 0 -944px !important;}
.language-flag-bn .country-flag {background-position: 0 -960px !important;}
.language-flag-eo .country-flag {background-position: 0 -976px !important;}
.language-flag.language-flag-custom-afghanistan .country-flag {background-position: 0 -992px !important;}
.language-flag.language-flag-custom-albania .country-flag {background-position: 0 -1008px !important;}
.language-flag.language-flag-custom-algeria .country-flag {background-position: 0 -1024px !important;}
.language-flag.language-flag-custom-argentina .country-flag {background-position: 0 -1040px !important;}
.language-flag.language-flag-custom-australia .country-flag {background-position: 0 -1056px !important;}
.language-flag.language-flag-custom-austria .country-flag {background-position: 0 -1072px !important;}
.language-flag.language-flag-custom-belgium .country-flag {background-position: 0 -1088px !important;}
.language-flag.language-flag-custom-brazil .country-flag {background-position: 0 -1104px !important;}
.language-flag.language-flag-custom-canada .country-flag {background-position: 0 -1120px !important;}
.language-flag.language-flag-custom-chile .country-flag {background-position: 0 -1136px !important;}
.language-flag.language-flag-custom-cote-d-ivoire .country-flag {background-position: 0 -1152px !important;}
.language-flag.language-flag-custom-ecuador .country-flag {background-position: 0 -1168px !important;}
.language-flag.language-flag-custom-egypt .country-flag {background-position: 0 -1184px !important;}
.language-flag.language-flag-custom-england .country-flag {background-position: 0 -1200px !important;}
.language-flag.language-flag-custom-luxembourg .country-flag {background-position: 0 -1216px !important;}
.language-flag.language-flag-custom-malaysia .country-flag {background-position: 0 -1232px !important;}
.language-flag.language-flag-custom-mexico .country-flag {background-position: 0 -1248px !important;}
.language-flag.language-flag-custom-new-zealand .country-flag {background-position: 0 -1264px !important;}
.language-flag.language-flag-custom-oman .country-flag {background-position: 0 -1280px !important;}
.language-flag.language-flag-custom-qatar .country-flag {background-position: 0 -1296px !important;}
.language-flag.language-flag-custom-saudi-arabia .country-flag {background-position: 0 -1312px !important;}
.language-flag.language-flag-custom-singapore .country-flag {background-position: 0 -1328px !important;}
.language-flag.language-flag-custom-south-africa .country-flag {background-position: 0 0 !important;}
.language-flag.language-flag-custom-switzerland .country-flag {background-position: 0 -1344px !important;}
.language-flag.language-flag-custom-syria .country-flag {background-position: 0 -1360px !important;}
.language-flag.language-flag-custom-united-arab-emirates .country-flag {background-position: 0 -1376px !important;}
.language-flag.language-flag-custom-united-states-of-america .country-flag {background-position: 0 -1392px !important;}
.language-flag-hy .country-flag {background-position: 0 -1408px;}
.language-flag-bs .country-flag {background-position: 0 -1424px;}
.language-flag-ceb .country-flag {background-position: 0 -1440px;}
.language-flag-ny .country-flag {background-position: 0 -1456px;}
.language-flag-ha .country-flag {background-position: 0 -1472px;}
.language-flag-hmn .country-flag {background-position: 0 -1488px;}
.language-flag-ig .country-flag {background-position: 0 -1504px;}
.language-flag-jw .country-flag {background-position: 0 -1520px;}
.language-flag-kk .country-flag {background-position: 0 -1536px;}
.language-flag-km .country-flag {background-position: 0 -1552px;}
.language-flag-lo .country-flag {background-position: 0 -1568px;}
.language-flag-la .country-flag {background-position: 0 -1584px;}
.language-flag-mg .country-flag {background-position: 0 -1600px;}
.language-flag-ml .country-flag {background-position: 0 -1616px;}
.language-flag-mi .country-flag {background-position: 0 -1632px;}
.language-flag-mr .country-flag {background-position: 0 -1648px;}
.language-flag-mn .country-flag {background-position: 0 -1664px;}
.language-flag-my .country-flag {background-position: 0 -1680px;}
.language-flag-ne .country-flag {background-position: 0 -1696px;}
.language-flag-pa .country-flag {background-position: 0 -1712px;}
.language-flag-st .country-flag {background-position: 0 -1728px;}
.language-flag-si .country-flag {background-position: 0 -1744px;}
.language-flag-so .country-flag {background-position: 0 -1760px;}
.language-flag-su .country-flag {background-position: 0 -1776px;}
.language-flag-tg .country-flag {background-position: 0 -1792px;}
.language-flag-uz .country-flag {background-position: 0 -1808px;}
.language-flag-yo .country-flag {background-position: 0 -1824px;}
.language-flag-zu .country-flag {background-position: 0 -1840px;}
.header{
    position: absolute;
    left: 0;
    top: 0;
    z-index: 12;
    width: 100%;
    background: #fff;
    box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.03);
}
.header .logo{
    padding: 20px 0;
}
.header .logo img{
    height: 50px;
    object-fit: contain;
}
.header.act{
    position: fixed;
}
.ht_lg{
    margin-left: 12px;
}
.ht_lg>p{
    padding: 0 4px;
}
.ht_lg>a{
    margin: 0 5px;
    position: relative;
}
.ht_lg>a.act:before{
    content: '';
    display: block;
    position: absolute;
    top: calc(100% + 4px);
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 8px solid transparent; 
    border-right: 8px solid transparent; 
    border-bottom: 8px solid #031663;
}
.ht_r{
    margin-bottom: 10px;
}
.hzw{
    height: 150px;
}
.ht_r_ct{
    position: absolute;
    left: 0;
    top: calc(100% + 6px);
    white-space: nowrap;
}
.in_on>a{
    height: 55px;
    padding: 0 50px;
    background: var(--c1);
    display: flex;
    font-weight: 600;
    align-items: center;
    font-size: 15px;
    color: #fff;
    transition: .3s;
}
.in_on>a:hover{
    background: var(--c4);
    color: #fff;
}
.in_on>a>img{
    width: 15px;
    height: 13px;
    object-fit: contain;
    margin-left: 10px;
    transition: .3s;
}
.in_on>a:hover>img{
    
}
.header .in_on>a{
    height: 50px;
}
.bg_c{
    background-size: cover;
    background-position: center;
}
.gotop{
    display: none;
}
.gotop.act{
    display: block;
}
.r_sns{
    position: fixed;
    z-index: 11;
    right: 0;
    top: 30vh;
}
.r_sns>ul{
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}
.r_sns>ul>li{
    box-shadow: 0 0 2px 0 #e7e7e7;
}
.r_sns>ul>li>a{
    height: 50px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .3s;
    background: #fff;
}
.r_sns>ul>li>a>.r_sns_img{
    width: 50px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.r_sns>ul>li>a>.r_sns_img>img{
    width: 24px;
    aspect-ratio: 1;
    object-fit: contain;
}
.r_sns>ul>li>a>p{
    font-size: 16px;
    white-space: nowrap;
    max-width: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    color: #fff;
    height: 50px;
    transition: .3s;
}
.r_sns>ul>li>a:hover{
    background: var(--c4);
}
.r_sns>ul>li>a:hover>.r_sns_img>img{
    filter: brightness(0) invert(1);
}
.r_sns>ul>li>a:hover>p{
    max-width: 300px;
    padding-left: 15px;
}
.r_sns>ul>li.gotop>a>.r_sns_img{
    background: var(--c4);
}
.h_search,.h_language{
    margin-right: 25px;
    position: relative;
}
.h_search>a,.h_language>.language-flag>a{
    display: flex;
    align-items: center;
    justify-content: center;
}
.h_search>a>img,.h_language>.language-flag>a>img{
    width: 20px;
    height: 20px;
    object-fit: contain;
    transition: .3s;
}
.h_language>.language-flag>a>img,.h_language>.language-flag>a>i{
    margin-left: 5px;
}
.h_search>a>img:hover,.h_language>.language-flag>a>img:hover{
    filter: brightness(0);
}
.h_search_box{
    /*position: fixed;*/
    /*background: rgba(0, 0, 0, 0.45);*/
    /*left: 0;*/
    /*right: 0;*/
    /*top: 0;*/
    /*bottom: 0;*/
    /*z-index: 12;*/
    /*display: none;*/
    /*width: 100%;*/
    /*height: 100%;*/
    /*justify-content: center;*/
    /*align-items: center;*/
    position: absolute;
    right: 0;
    width: 300px;
    background: #fff;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 2px 0 0px;
    top: calc(100% + 10px);
    padding: 12px;
    border-radius: 10px;
    border: 1px solid #ccc;
    display: none;
    z-index: 2;
}
.h_search.act .h_search_box{
    display: flex;
}
.h_search_f{
    /*padding: 6vh;*/
    width: 100%;
    background: #fff;
    position: relative;
}
.h_search_f>.h_search_t{
    margin-bottom: 10px;
}
.h_search_close{
    position: absolute;
    top: 10px;
    right: 20px;
    cursor: pointer;
    z-index: 2;
}
.h_search_f input,.h_search_f button{
    outline: none;
    vertical-align: middle;
}
.h_search_f form{
    width: 100%;
}
.h_search_f .search-ipt{
    width: calc(100% - 40px);
    height: 40px;
    border: 1px solid #d2d2d2;
    padding-left: 20px;
}
.search-btn{
    background: var(--c2);
    width: 40px;
    height: 40px;
    padding: 0;
    border: 0;
    transition: .3s;
    cursor: pointer;
}
.search-btn:hover{
    background: var(--c1);
    /*color: #000;*/
}
.header .nav>ul{
    
}
.header .nav>ul>li{
    height: 60px;
}
.header .nav>ul>li>a{
    height: 60px;
    display: flex;
    align-items: center;
    position: relative;
}
.header .nav>ul>li>a:before{
    content: '';
    position: absolute;
    width: 100%;
    height: 2px;
    bottom: 10px;
    transform: scaleX(0);
    transition: .3s;
    left: 0;
    background-color: #031663;
}
.header .nav>ul>li>a>i{
    margin-left: 8px;
    transition: .3s;
}
.header .nav>ul>li:hover>a,.header .nav>ul>li.act>a{
    color: var(--c1);
}
.header .nav>ul>li.act>a{
    font-weight: 700;
}
.header .nav>ul>li:hover>a:before,.header .nav>ul>li.act>a:before{
    transform: scaleX(1);
}
.header .nav>ul>li:hover>a>i{
    transform: rotate(180deg);
}
.header .nav>ul>li li{
    position: relative;
    margin-bottom: 1px;
}
.header .nav>ul>li ul{
    position: absolute;
    visibility: hidden;
    opacity: 0;
    top: 100%;
    left: 0;
    transition: .3s;
    background: #fff;
    transform: translateY(-20px);
    overflow: auto;
}
.header .nav>ul>li>ul ul{
    left: 100%;
    top: 0;
    transform: translateY(-20px);
}
.header .nav>ul>li li>a{
    display: flex;
    height: 52px;
    align-items: center;
    padding: 0 20px;
    white-space: nowrap;
}
.header .nav>ul>li li>a>img{
    width: 26px;
    aspect-ratio: 1;
    object-fit: contain;
    margin-right: 10px;
}
.header .nav>ul>li li>a:hover{
    color: #fff;
    background: var(--c1);
}
.header .nav>ul li:hover>ul{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.pro_nav{
    position: absolute;
    width: 670px;
    left: 0;
    background: #fff;
    transition: .3s;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    z-index: 10;
}
.header .nav>ul>li:hover .pro_nav{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.pro_nav_lv1{
    border-bottom: 1px solid #eee;
}
.pro_nav_lv1_l{
    width: 310px;
    padding: 5px 20px;
}
.pro_nav_lv1_l>.df{
    padding: 2px 0;
    margin-bottom: 5px;
}
.pro_nav_lv2>a{
    margin-right: 15px;
    white-space: nowrap;
}
.pro_nav_lv1_img{
    padding:8px 20px 8px 0;
    width: 360px;
}
.pro_nav_lv1_img .ci100{
    border-radius: 10px;
    overflow: hidden;
}
.pro_nav_lv1_img a{
    background: #03166399;
}
.pro_nav_lv1:hover .pro_nav_lv1_img a{
    background: none;
    color: var(--c1);
}
.ft_ct{
    padding: 50px 0;
}
.ft_ct_l{
    max-width: calc(100% - 200px);
}
.ft_ct .in_on>a{
    border-color: #fff;
    color: #fff;
}
.ft_ct .in_on>a:hover{
    background: #fff;
    color: var(--c1);
}
.nfooter{
    background-repeat: no-repeat;
    background-size: 40%;
    background-position: 20% 80px;
    background-color: #0E0E0E;
    padding-top: 84px;
}
.f_logo{
    /*position: absolute;*/
    position: relative;
    margin-bottom: 30px;
    left: 0;
    /*top: -110px;*/
    /*display: none;*/
}
.f_logo>a{
    display: block;
}
.f_logo>a>img{
    width: 310px;
    height: 54px;
    object-fit: contain;
}
.nfooter_l1{
    margin-right: 90px;
}
.nfooter_l2{
    margin-right: 20px;
    width: 13%;
}
.nfooter_l3{
    margin-right: 62px;
}
.nfooter_l4{
    margin-right: 70px;
    width: 24%;
}
.nfooter_tl{
    flex-direction: row-reverse;
    justify-content: flex-end;
}
.nfooter_tl li a.nw{
    white-space: nowrap;
}
.nfooter_tl li a{
    color: #BDBCC0;
    line-height: 32px;
}

.nfooter_tl li a:hover{
    color: #fff;
}
.nfooter_copyright{
    padding: 20px 0 40px;
    border-top: 1px solid #282A29;
}
.nfooter_copyright,.nfooter_copyright p,.nfooter_copyright a{
    font-size: 14px;
    color: #5A5D5B;
}
.nfooter_copyright a:hover{
    color: #fff;
}
.ot_banner_b{
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    z-index: 2;
}
.pro_page{
    margin-top: 20px;
}

.nfooter_sns{
    display: flex;
    align-items: center;
}
.nfooter_sns>a{
    margin-left: 27px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.nfooter_sns>a:nth-child(1){
    margin-left: 0;
}
.nfooter_sns>a>img{
    height: 25px;
    aspect-ratio: 1;
    filter: brightness(0) invert(1);
    object-fit: contain;
    transition: .3s;
}
.nfooter_sns>a:nth-child(2)>img{
    width: 45px;
}
.nfooter_sns>a:hover>img{
    filter: brightness(0) invert(1);
}
.nfooter_sns>a .nfooter_sns_qr{
    position: absolute;
    right: -17px;
    top: 52px;
    background: #FFFFFF;
    border-radius: 10px;
    padding: 10px;
    transition: .3s;
    visibility: hidden;
    opacity: 0;
    z-index: 2;
}
.nfooter_sns>a .nfooter_sns_qr img{
    width: 143px;
    aspect-ratio: 1;
    object-fit: contain;
}
.nfooter_sns>a:hover .nfooter_sns_qr{
    visibility: visible;
    opacity: 1;
}
.nfooter_sns>a .nfooter_sns_qr:before{
    position: absolute;
    content: '';
    width: 0;
    height: 0;
    border: 10px solid transparent;
    border-bottom-color: #FFFFFF;
    right: 30px;
    top: -19px;
    z-index: 2;
}
.nfooter_qr{
    width: 100px;
    /*margin: 35px 0 0 23px;*/
    margin-top: 20px;
}
.nfooter_qr>img{
    aspect-ratio: 1;
    object-fit: contain;
}

.nfooter_phone>img{
    width: 33px;
    height: 37px;
    margin-right: 10px;
    margin-top: 5px;
}
.nfooter_phone>div{
    width: calc(100% - 43px);
}
.nfooter_phone a:hover{
    color: var(--c4);
}
.nfooter_add>img,.nfooter_el>img{
    width: 16px;
    aspect-ratio: 1;
    object-fit: contain;
    margin-top: 6px;
    margin-right: 10px;
}
.nfooter_add>p,.nfooter_el>p{
    width: calc(100% - 26px);
}
.nfooter_el a:hover{
    color: var(--c1);
    text-decoration: underline;
}
.nfooter_copyright .icp{
    margin-left: 30px;
}

.ot_nav{
    display: flex;
    align-items: center;
    height: 42px;
    background: #F8F8F8;
}
.ot_nav .df{
    height: 42px;
}
.ot_nav,.ot_nav a{
    color: #787878;
}
.ot_nav a:hover{
    color: #787878;
}
.ot_nav a:last-child{
    color: #031663;
}
.ot_nav a:last-child:hover{
    color: #031663;
}
.faq_title{
    height: 60px;
    padding-left: 30px;
    padding-right: 50px;
    display: flex;
    align-items: center;
    position: relative;
    cursor: pointer;
}
.faq_title:before{
    content: '';
    display: block;
    position: absolute;
    width: 12px;
    height: 7px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%;
    background-image: url(/themes/template/static/css/img/ic_t.webp);
    right: 30px;
    top: 50%;
    transform: translateY(-50%);
}
.faq_content{
    transition: .5s;
    padding: 0 30px;
    max-height: 0;
    overflow: hidden;
}
.faq_list{
    border-bottom: 1px solid #EBEBEB;
}
.faq_list.act .faq_title{
    background: #F6F7F9;
}
.faq_list.act .faq_title:before{
    transform: translateY(-50%) rotate(180deg);
    filter: brightness(0);
}
.faq_list.act .faq_content{
    padding: 30px 30px 50px;
    max-height: 1000px;
}
.index_banner .swiper-pagination .swiper-pagination-bullet-active{
    width: 16px;
    background: var(--c1);
    border-radius: 4px;
}
.index_banner .swiper-button-next:after,.index_banner .swiper-button-prev:after{
    display: none;
}
.index_banner .swiper-button-next,.index_banner .swiper-button-prev{
    opacity: 0;
    visibility: hidden;
    width: 42px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: #00000055;
    color: #fff;
    font-size: 22px;
    transition: .3s;
}
.index_banner:hover .swiper-button-next,.index_banner:hover .swiper-button-prev{
    opacity: 1;
    visibility: visible;
}
@media(max-width:1600px){
    
}
@media(max-width:1500px){
    .mw1700{
        padding: 0 20px;
    }
    .mw1600{
        padding: 0 30px;
    }
    
}
@media(max-width:1400px){
    .nf_formbox{
        padding-left: 2vw;
    }
    .fsxl40{
        font-size: 40px;
    }
    .fsxl16{
        font-size: 16px;
    }
}
@media(max-width:1300px){
    .mw1700{
        padding: 0 15px;
    }
    .header .nav>ul>li{
        margin-right: 1.15vw;
    }
    .nfooter_l4,.nfooter_l5{
        width: 50%;
        margin-right: 0;
    }
    .nfooter_l3,.nfooter_l2,.nfooter_l1{
        width: 33.3%;
        margin-right: 0;
        padding-right: 20px;
    }
}
@media(max-width:1200px){
    .fsx12{
        font-size: 12px;
    }
    .fsx14{
        font-size: 14px;
    }
    .fsx16{
        font-size: 16px;
    }
    .fsx18{
        font-size: 18px;
    }
    .fsx20{
        font-size: 20px;
    }
    .fsx22{
        font-size: 22px;
    }
    .fsx23{
        font-size: 23px;
    }
    .fsx24{
        font-size: 24px;
    }
    .fsx25{
        font-size: 25px;
    }
    .fsx26{
        font-size: 26px;
    }
    .fsx30{
        font-size: 30px;
    }
    .mtx20{
        margin-top: 20px;
    }
    .mtx10{
        margin-top: 10px;
    }
    .ptx10{
        padding-top: 10px;
    }
    .ptx20{
        padding-top: 20px;
    }
    .ptx30{
        padding-top: 30px;
    }
    .ptx40{
        padding-top: 40px;
    }
    .ptx50{
        padding-top: 50px;
    }
    .ptx60{
        padding-top: 60px;
    }
    .mw1400{
        padding: 0 10px;
    }
    .mw1500{
        padding: 0 10px;
    }
    .mw1700{
        padding: 0 10px;
    }
    .header .in_on{
        display: none;
    }
    .wx25{
        width: 25%;
    }
    .wx33{
        width: 33.3%;
    }
    .wx50{
        width: 50%;
    }
    .wx100{
        width: 100%;
    }
    .nfooter{
        background-position: 10% 50px;
    }
}
@media(max-width:1100px){
    
}
@media(max-width:990px){
    .d_n{
        display: none;
    }
    .mw1600,.mw1200{
        padding: 0 10px;
    }
    .fsl12{
        font-size: 12px;
    }
    .fsl14{
        font-size: 14px;
    }
    .fsl16{
        font-size: 16px;
    }
    .fsl18{
        font-size: 18px;
    }
    .fsl20{
        font-size: 20px;
    }
    .fsl23{
        font-size: 23px;
    }
    .fsl24{
        font-size: 24px;
    }
    .fsl25{
        font-size: 25px;
    }
    .fsl26{
        font-size: 26px;
    }
    .fsl30{
        font-size: 30px;
    }
    .plr10{
        padding-left: 6px;
        padding-right: 6px;
    }
    .mtl20{
        margin-top: 20px;
    }
    .mtl10{
        margin-top: 10px;
    }
    .p10{
        padding: 6px;
    }
    .ptl10{
        padding-top: 10px;
    }
    .ptl20{
        padding-top: 20px;
    }
    .ptl30{
        padding-top: 30px;
    }
    .ptl40{
        padding-top: 40px;
    }
    .ptl50{
        padding-top: 50px;
    }
    .ptl60{
        padding-top: 60px;
    }
    .hzw{
        height: 60px;
    }
    .header{
        height: 60px;
    }
    .hzw{
        height: 60px;
    }
    .header .logo{
        width: 100%;
        text-align: left;
    }
    .wl33{
        width: 33.3%;
    }
    .wl50{
        width: 50%;
    }
    .wl100{
        width: 100%;
    }
    .in_on>a{
        height: 40px;
        padding: 0 10px;
        font-size: 12px;
    }
    .in_on>a>img{
        margin-left: 4px;
        width: 8px;
        height: 16px;
    }
    .header .logo img{
        width: 150px;
    }
    .br20{
        border-radius: 10px;
    }
    .ft_ct{
        padding: 20px 0;
    }
    .ft_ct_l{
        max-width: none;
        width: 100%;
    }
    .ft_ct .in_on{
        margin-top: 10px;
    }
    .r_sns{
        right: 0;
        top: auto;
        bottom: 0;
        width: 100%;
    }
    .r_sns>ul{
        flex-direction: row;
    }
    .r_sns>ul>li{
        width: 33.3%;
    }
    .nfooter_sns{
        margin-top: 10px;
        width: 100%;
        margin-left: 0;
    }
    .nfooter_top{
        margin-bottom: 20px;
        padding-bottom: 20px;
    }
    .nfooter_bottom_l{
        width: 50%;
        max-width: none;
    }
    .faq_title{
        padding-left: 10px;
        padding-right: 30px;
    }
    .faq_content{
        padding: 0 10px;
    }
    .faq_list.act .faq_content{
        padding: 10px 10px 20px;
        max-height: 1000px;
    }
    .r_sns>ul>li>a>p{
        display: none;
    }
    .r_sns>ul>li>a,.r_sns>ul>li>a>.r_sns_img{
        width: 100%;
    }
    .f_logo{
        /*top: -70px;*/
        margin-bottom: 20px;
    }
    .nfooter{
        padding-top: 50px;
    }
    .nfooter_sns>a .nfooter_sns_qr{
        right: auto;
        left: 0;
    }
    .nfooter_sns>a .nfooter_sns_qr:before{
        right: auto;
        left: 10px;
    }
}
@media(max-width:768px){
    .fsm12{
        font-size: 12px;
    }
    .fsm14{
        font-size: 14px;
    }
    .fsm16{
        font-size: 16px;
    }
    .fsm18{
        font-size: 18px;
    }
    .fsm20{
        font-size: 20px;
    }
    .fsm22{
        font-size: 22px;
    }
    .fsm24{
        font-size: 24px;
    }
    .ptm10{
        padding-top: 10px;
    }
    .ptm20{
        padding-top: 20px;
    }
    .ptm30{
        padding-top: 30px;
    }
    .ptm40{
        padding-top: 40px;
    }
    .wm50{
        width: 50%;
    }
    .wm100{
        width: 100%;
    }
    .f_logo>a>img{
        width: 200px;
    }
    .nfooter_bottom_l:nth-child(1){
        width: 100%;
        max-width: none;
    }
    .nfooter_l5{
        width: 100%;
    }
    .nfooter_l3, .nfooter_l1,.nfooter_l2{
        width: 33.3%;
    }
    .nfooter_l4{
        width: 100%;
    }
}