@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}
.only-desktop-mobile {display:block;}

#skipToContent a {z-index:100000;position:absolute;top:0;left:0;width:1px;height:1px;font-size:0;line-height:0;overflow:hidden}
#skipToContent a:focus, 
#skipToContent a:active {width:200px;height:50px;background:#21272e;color:#fff;font-size:14px;font-weight:bold;text-align:center;text-decoration:none;line-height:50px}

.contain {width:100%; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
#main .contain {max-width:1460px;}
.contain:after {content:" "; display:block; clear:both;}

/* header */
#header {position:absolute; width:100%; z-index:100; background:#fff;}
.sitelogo {position:absolute; top:50%; margin-top:-30px; left:100px; z-index:10}
.sitelogo a {display:block; width:202px; height:60px; overflow:hidden; text-indent:-9999em; background:url("../images/common/logo_w.png") 50% 50% no-repeat; background-size:contain;}

.main-visual .slick-slide img {width:100%; height:100vh;}
 

#header .contain {position:relative; height:100px; max-width:100%;}
#header.header-hover {background:rgba(255, 255, 255, 0.9);}
#header.header-hover #gnb > ul > li > a {color:#2c2c2c;} 
#header.header-hover #gnb > ul > li {color:#177a4c;}
#header.header-hover #gnb > ul {color:#177a4c; font-weight:500;}
#header.header-hover #gnb > ul > li:hover:after {transform: scaleX(1);}
#header.header-hover #gnb > ul.active {background:#fff; color:#2c2c2c;}
#header.header-hover .sitelogo {}

#sub #header.header-hover {background:#fff;} 
#sub #header.header-hover .btn-m-menu span {background:#000;}
#sub #header.header-hover .btn-m-menu span:before,
#sub #header.header-hover .btn-m-menu span:after {background:#000;}

#gnb {position:relative; display:flex; justify-content:space-evenly; height:100px; text-align:right;}
#gnb > ul {display:inline-block;}
#gnb > ul > li {float:left; position:relative; height:100px; z-index:1; color:#fff;}
#gnb > ul > li > a {display:block; height:100px; position:relative; padding:0 100px; text-align:center; font-size:20px; line-height:100px; font-weight:700; color:#333; letter-spacing:-0.04em; z-index:5;}
#gnb > ul > li:hover li {color:#2564a4;}
#header.header-hover #gnb > ul > li.active > a, 
#header.header-hover #gnb > ul > li:hover > a {color:#fff; background:#d21d4f;}
#header.header-hover #gnb > ul > li.active > .submenu, 
#header.header-hover #gnb > ul > li:hover > .submenu {background:#d21d4f;}
#header.header-hover #gnb > ul > li.active > .submenu > ul > li > a, 
#header.header-hover #gnb > ul > li:hover > .submenu > ul > li > a {color:#fff;} 
#header.header-hover .sitelogo a {background-image:url("../images/common/logo_w.png");}

#gnb .submenu {height:0; overflow:hidden; position:absolute; right:0; width:100%; text-align:center; z-index:15;}
#gnb .submenu > ul {position:relative; padding:15px 0;}
#gnb .submenu > ul > li {font-size:16px; line-height:26px;}
#gnb .submenu > ul > li > a {position:relative; display:inline-block; text-decoration:none; font-weight:500; padding:7px; color:#454545;}
#gnb .submenu > ul > li:hover > a {color:#2564a4; text-decoration:underline;} 

.submenu-txt {display:none; position:absolute;  padding:5px;left:350px; top:125px; z-index:2; color:#fff; font-size:20px; font-weight:bold;}
.submenu-txt a { font-family:'NanumSquare', sans-serif; position:relative; display:inline-block; }
.submenu-txt a span {position:relative; display:block; width:100%; height:0; padding-bottom:100%; overflow:hidden;}

.submenu-bg {position:relative; display:none; position:absolute; top:100px; left:0; width:100%; background-color:#fff; border-top:1px solid #ddd; overflow:hidden;}

.visual-scroll {position:absolute; left:50%; animation:pulse 2s infinite; bottom:80px; color:#fff; font-size:16px; letter-spacing:0.2em; margin-left:-30px;}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

@keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}
#rightMenu {position:fixed; top:50%; left:90px; transform:translateY(-50%); z-index:10;}
#rightMenu li {position:relative; margin-bottom:10px;}
#rightMenu li span {color:#b5b5b6;}
#rightMenu li.active span {opacity:1; color:#fff;} 
#rightMenu li a {display:block; position:relative; width:160px; padding-right:45px; font-size:14px; line-height:31px; color:#ddd;}
#rightMenu li a:before {content:""; position:absolute; top:50%; right:16px; margin-top:0.5px; width:4px; height:4px; border-radius:100%; background:#ddd;}
#rightMenu li a:after {content:""; position:absolute; top:50%; right:3px; margin-top:-12px; width:30px; height:30px; border-radius:100%; background:transparent;}
#rightMenu li.active a {color:#ddd; font-weight:500;}
#rightMenu li.active a:before {background:#fff;}
#rightMenu li.active a:after {border:2px solid #fff;}
#rightMenu li.last {display:none;}

/* 전체메뉴 */
.btn-all-menu {position:absolute; display:block; top:50%; right:100px; width:40px; height:34px; margin-top:-17px; text-align:center; text-indent:-9999em; z-index:50;}
.btn-all-menu span {position:absolute; left:20px; right:0; top:17px; height:2px; background:#000;}
.btn-all-menu span:before,
.btn-all-menu span:after {content:""; position:absolute; left:-11px; right:0; height:2px; background:#000;}
.btn-all-menu span:before {top:-10px;}
.btn-all-menu span:after {bottom:-10px;}

.allmenu {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#333; z-index:102;}
.allmenu .nav {height:100%; width:100%; max-width:1780px; padding-left:30px; padding-right:30px; margin:0 auto; display:flex; align-items:center;}
.allmenu .nav > ul {display:flex; width:100%;}
.allmenu .nav > ul > li {position:relative; height:100vh; display:flex; flex-direction:column; justify-content:center; flex:1; text-align:center;}
.allmenu .nav > ul > li:hover {background:#d21d4f;}
.allmenu .nav > ul > li:before {position:absolute; content:""; width:1px; height:100vh; background:rgba(255, 255, 255, 0.2); top:0; left:0;}
.allmenu .nav > ul > li:last-child:after {position:absolute; content:""; width:1px; height:100vh; background:rgba(255, 255, 255, 0.2); top:0; right:0;}
.allmenu .nav > ul > li:first-child {border-left:0;}
.allmenu .nav > ul > li > a {display:flex; flex-direction:column; justify-content:flex-end; margin-bottom:100px; color:#fff; font-size:40px; font-weight:700; line-height:1.2em;}
.allmenu .nav .submenu {min-height:295px;}
.allmenu .nav .submenu ul li {padding:8px 0;}
.allmenu .nav .submenu ul li a {display:block; color:#fff; font-size:20px; font-weight:500; line-height:1.4em; letter-spacing:0; height:60px; line-height:60px;}
.allmenu .nav .submenu ul li:hover a {background:#fff; font-weight:700; color:#d21d4f;} 
.allmenu .close {position:absolute; top:0; right:0; width:100px; height:120px; text-indent:-9999em; overflow:hidden;}
.allmenu .close:before,
.allmenu .close:after {content:" "; position:absolute; top:50%; left:50%; margin:-2px 0 0 -15px; width:30px; height:3px; background:#fff;}
.allmenu .close:before {transform:rotate(45deg);}
.allmenu .close:after {transform:rotate(-45deg);}

html.all-menu-opened {overflow:hidden;}
html.all-menu-opened .allmenu {display:block;}

/* for mobile */
.btn-m-menu {position:absolute; display:none; top:50%; right:100px; width:40px; height:34px; margin-top:-17px; text-align:center; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:20px; right:0; top:17px; height:2px; background:#000;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:""; position:absolute; left:-11px; right:0; height:2px; background:#000;}
.btn-m-menu span:before {top:-15px;}
.btn-m-menu span:after {bottom:-15px;}

.mobile-navigation {position:fixed; display:none; top:0; right:0; width:300px; bottom:0; transition:.2s ease-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .inner {position:absolute; top:0; left:0; width:100%; height:100%; overflow:auto;}
.mobile-navigation .brand-image {border-bottom:1px solid #d6dfd1; background-color:#e9ede7; height:128px;}
.mobile-navigation .brand-image a {display:block; padding-top:40px; padding-left:40px;}
.mobile-navigation .nav-menu .depth3 {display:block; margin-left:23px; padding-bottom:18px;}
.mobile-navigation .nav-menu .depth3 ul li a {display:block; padding:4px 0; color:#fff; font-size:18px; font-weight:300; line-height:1.4em; letter-spacing:-.04em;}
.mobile-navigation .close {position:absolute; top:18px; right:22px; width:26px; height:26px; text-indent:-9999em; overflow:hidden;} 
.mobile-navigation .close:before, 
.mobile-navigation .close:after {content:" "; position:absolute; top:12px; left:0; width:100%; height:3px; background:#2c2c2c; border-radius:3px;} 
.mobile-navigation .close:before {transform:rotate(45deg);} 
.mobile-navigation .close:after {transform:rotate(-45deg);} 
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.8; z-index:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-navigation .close {display:block;}
html.menu-opened .mobile-overlay {display:block;}

nav.nav-menu {position:relative; border-top:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:10px 18px; display:block; color:#333; font-size:17px; font-weight:500; line-height:1.3em;}
.mobile-navigation .nav-menu>ul>li.active {background:#f4f4f4}
.mobile-navigation .nav-menu>ul>li.active>a {color:#fff; background:#d21d4f;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#fff}
.mobile-navigation .nav-menu>ul>li.home>a {padding:19px 18px;}
.mobile-navigation .nav-menu>ul>li.home>a:after {display:none;}
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:10px 0;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; padding:5px 18px; color:#454545; font-size:15px; font-weight:400; line-height:1.4em;}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover {color:#d21d4f;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:12px; height:12px; border-right:2px solid #242424; border-bottom:2px solid #242424;}
.mobile-navigation img {width:40%; margin:17px;}
.mobile-navigation .close {position:absolute; top:16px; right:10px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:11px; left:0; width:100%; height:2px; background:#242424; border-radius:3px;}
.mobile-navigation .close:before {transform:rotate(45deg);}
.mobile-navigation .close:after {transform:rotate(-45deg);}


.btn-m-menu span:before, .btn-m-menu span:after {left:-10px;}
.btn-m-menu span:before {top:-10px;}
.btn-m-menu span:after {bottom:-10px;}

/* main */ 
.sec-cnt {height:450px;} 

#fp-nav {position:fixed; top:50%; left:50px !important; transform:translateY(-50%); z-index:10;}
#fp-nav.left {left:50px !important;}
#fp-nav li {position:relative; margin-bottom:10px;}
#fp-nav li span {display:block; color:#898989; font-weight:500; padding-left:10px; padding-top:7.5px; opacity:0;}
#fp-nav li a.active span {opacity:0; color:#be1522;} 
#fp-nav li a {display:block; position:relative; width:0; padding-right:0; font-size:14px; line-height:31px; color:#666;}
#fp-nav li a:before {content:""; position:absolute; top:50%; margin-top:-5px; left:0; width:10px; height:10px; background:transparent; border:2px solid #fff;}
#fp-nav li a.active {background:#fff; font-weight:500;} 
#fp-nav li.last {display:none;}
 

.fp-viewing-Philosophy #fp-nav li a.active {background:#d21d4f;}
.fp-viewing-Philosophy #fp-nav li a:before {border-color:#d21d4f;}

.fp-viewing-Main-visual #header {background:transparent;}
.fp-viewing-Main-visual #header.header-hover {background:#fff;}
.fp-viewing-Main-visual #gnb > ul > li > a {color:#fff;}
.fp-viewing-Main-visual .sitelogo a {background-image:url("../images/common/logo.png")}
.fp-viewing-Main-visual .btn-all-menu span {position:absolute; left:20px; right:0; top:17px; height:2px; background:#fff;}
.fp-viewing-Main-visual .btn-all-menu span:before,
.fp-viewing-Main-visual .btn-all-menu span:after {content:""; position:absolute; left:-11px; right:0; height:2px; background:#fff;}
.fp-viewing-Main-visual #header.header-hover .btn-all-menu span {background:#000;}
.fp-viewing-Main-visual #header.header-hover .btn-all-menu span:before,
.fp-viewing-Main-visual #header.header-hover .btn-all-menu span:after {background:#000;}

.fp-viewing-Strategy #fp-nav li a.active {background:#d21d4f;}
.fp-viewing-Strategy #fp-nav li a:before {border-color:#d21d4f;}

#sub #header {border-bottom:1px solid rgba(255, 255, 255, 0.3); background:transparent;} 
#sub #gnb > ul > li > a {color:#fff;}  
#sub .sitelogo a {background-image:url("../images/common/logo.png");}

#sub .btn-all-menu span {background:#fff;}
#sub .btn-all-menu span:before,
#sub .btn-all-menu span:after {background:#fff;}


.main-visual {position:relative; overflow:hidden;}
.main-visual .contain {max-width:1460px !important;}
.main-visual .caption {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; color:#fff; text-align:left; z-index:40;}
.main-visual .caption p {font-size:20px; font-weight:600; line-height:1.700em; letter-spacing:-.05em;}
.main-visual .caption h2 {font-size:55px; line-height:1.3em; letter-spacing:-.05em; margin:60px 0 20px;}
.main-visual .caption .txt1 {font-size:34px; line-height:1.3em; letter-spacing:-.05em; margin:60px 0 20px;}
.main-visual .caption .bold {font-weight:500;}
.main-visual .slick-arrow {width:12px; height:19px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-visual .slick-prev {background-image:url("../images/main/main-prev.png");}
.main-visual .slick-next {background-image:url("../images/main/main-next.png");}
.main-visual .btn-flex {display:flex; justify-content:space-between; align-items:center; margin-top:100px; max-width:260px;}
.main-visual .name {font-size:3px;}

.main-visual .btn {display:flex; align-items: center; width:180px; height:44px; line-height:44px; border:1px solid rgba(255, 255, 255, 0.3); padding:0 30px; color:#fff; margin-top:50px; border-radius:30px;}
.main-visual .btn:hover {background:#fff; color:#327393;}
.main-visual .btn span {font-size:20px; padding-left:20px;}

.main-visual .auto-control {margin-top:200px; display:flex; align-items:center; z-index:50; width:100%; max-width:350px; margin-top:350px;}
.main-visual .paging {margin-left:40px; font-family:'pretendard'; font-size:16px; font-weight:500; margin-right:20px; color:#fff; line-height:1.3em; letter-spacing:0; display: flex; white-space: nowrap;}
.main-visual .paging .current {position:relative; padding-right:8px; margin-right:5px;}
.main-visual .paging .current span {margin-right:-3px;}
.main-visual .paging .current:before {position:absolute; content:""; width:2px; height:18px; background:#fff; top:50%; margin-top:-9px; right:0; transform:rotate(10deg);}
.main-visual .dots {width:160px; margin:0 30px;}

.main-visual .slick-dots  {display:flex; position:relative;}
.main-visual .slick-dots li {display:inline-block; position:absolute; left:0;}
.main-visual .slick-dots li button {display:none; position:relative; border:0; font-size:16px; font-weight:500; line-height:1.4em; color:#fff; background:0;}
.main-visual .slick-dots li.slick-active button {display:block; text-indent:-999em;}

.main-visual .slick-dots li.slick-active button:before  {content:""; position:absolute; left:0px; height:4px; width:160px; background:rgba(255,255,255,0.5);}
.main-visual .slick-dots li.slick-active button:after {content:""; position:absolute;left:0px; height:4px; width:0; background:#fff; animation:proBar 3s 0.3s 1;}


.main-visual .prev {position:relative; width:13px; height:13px; border:0; background:0; border-left:2px solid #fff; border-top:2px solid #fff; transform:rotate(-45deg);}
.main-visual .next {position:relative;width:13px;height:13px;border:0;background:0;border-right:2px solid #fff;border-top:2px solid #fff;transform:rotate(45deg);}
.main-visual .stop {position:relative; width:30px; height:16px; background-color:transparent; border:0;}
.main-visual .stop:after {content:""; position:absolute; left:50%; top:50%; width:10px; height:21px; margin:-10.5px 0 0 -3px; border-left:2px solid #fff; border-right:2px solid #fff;}
.main-visual .play {display:none; position:relative; width:16px; height:16px; background-color:transparent; border:0;}
.main-visual .play:after {content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:0; height:0; display:inline-block; border-left:19px solid #fff; border-top:11px solid transparent; border-bottom:11px solid transparent; margin-left:11px;}

@keyframes proBar{
    0%{width:0;}
    100%{width:160px;}
}

@keyframes m_proBar{
    0%{width:0;}
    100%{width:100px;}
}


.visual-scroll {position:absolute; width:99px; height:46px; margin-left:-49.5px; left:50%; animation:pulse 2s infinite; bottom:80px; color:#fff; font-size:16px; letter-spacing:0.2em; margin-left:-30px;}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

@keyframes pulse {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  50% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } 
}

 
.doc-tit {margin-bottom:25px;}
.doc-tit h3 {position:relative; font-size:26px; font-weight:600; color:#333; letter-spacing:-.03em; line-height:1.154em; padding-left:43px;}
.doc-tit h3:before {position:absolute; content:""; width:35px; height:33px; background:url('../images/sub/doc-tit.png')50% 50% no-repeat; background-size:contain; top:50%; margin-top:-16.5px; left:0;}

/* Main-technology */
.Main-technology {text-align:center; padding-top:100px;}
.Main-technology .main-tit-wrap {transition: all 1s ease-out 0s; position:relative; top:-70px; opacity:0;}
.section.Main-technology.active .main-tit-wrap {opacity:1; top:0;}
.Main-technology .main-tit {margin-bottom:30px;}
.Main-technology .main-tit h3 {font-family:'Poppins', sans-serif; font-size:55px; font-weight:700; letter-spacing:0; color:#222; line-height:1.3em;}
.Main-technology .main-tit h3 span {color:#d21d4f;}
.Main-technology .tit {font-size:20px; font-weight:600; color:#333; letter-spacing:-.03em; line-height:1.5em;}
.Main-technology .txt {font-size:20px; color:#454545; letter-spacing:-.03em; line-height:1.5em; margin-bottom:70px;}
.Main-technology .main-access-list {transition: all 1s ease-out 0s; position:relative; top:-70px; opacity:0; margin-bottom:120px;}
.section.Main-technology.active .main-access-list {opacity:1; top:0;}
.Main-technology .main-access-list ul {display:flex; margin:0 -70px;}
.Main-technology .main-access-list ul li {width:25%; padding:0 70px; filter: drop-shadow(7px 0 7px rgba(0, 0, 0, 0.29));}

.main-relation .slick-list {overflow:visible;}

/* Main-business */
.Main-business {background-repeat:no-repeat; background-size:cover; background-position:50% 50%;}
.main-product-wrap {display:flex;}
.main-product-wrap .main-product-flex {transition: all 1s ease-out 0s; position:relative; left:-70px; opacity:0; width:32%;}
.main-product-wrap .main-product-flex .main-tit {margin-bottom:45px;}
.section.Main-business.active .main-product-flex {opacity:1; left:0;}
.main-product-wrap .main-product-flex .main-tit p {font-family:'Poppins', sans-serif; font-size:26px; font-weight:700; letter-spacing:-.02em; color:#d21d4f; line-height:1.3em; margin-bottom:10px;}
.main-product-wrap .main-product-flex .main-tit h3 {font-size:60px; color:#fff; letter-spacing:-.02em; line-height:1.3em;}
.main-product-wrap .main-product-flex .txt {font-size:18px; color:#fff; line-height:1.556em;}
.main-product-wrap .main-product-flex .txt strong {font-weight:600;}
.main-product-wrap .main-product-flex .txt span {display:inline-block; margin-top:10px;}
.main-product-wrap .main-product-list {transition: all 1s ease-out 0s; position:relative; right:-70px; opacity:0; margin-right:-170px;}
.section.Main-business.active .main-product-wrap .main-product-list {opacity:1; right:0;}
.main-product-wrap .main-product-list ul {display:flex; margin:0 -15px;}
.main-product-wrap .main-product-list ul li {transition: all .3s ease-out 0s; padding:0 15px;}
.main-product-wrap .main-product-list ul li:hover {margin-top:-60px;}
.main-product-wrap .main-product-list ul li:hover .img img {box-shadow:11px 0 40px rgba(0, 0, 0, 0.42);}
.main-product-wrap .main-product-list ul li:nth-child(n+2) {}
.main-product-wrap .main-product-list ul li .img img {border-radius:5px;}

/* Contact */
.main-contact-flex {display:flex;}
.main-contact-flex .main-contact-box {transition: all 1s ease-out 0s; position:relative; left:-70px; opacity:0; width:48%;}
.section.main-contact.active .main-contact-flex .main-contact-box {opacity:1; left:0;}
.main-contact-flex .main-contact-box .main-tit {margin:85px 0 25px;}
.main-contact-flex .main-contact-box .main-tit h3 {font-family:'Poppins', sans-serif; font-size:55px; color:#222; letter-spacing:0; line-height:1.3em;}
.main-contact-flex .main-contact-box .main-tit h3 span {color:#d21d4f;}
.main-contact-flex .main-contact-box .txt {font-size:20px; color:#454545; letter-spacing:-.03em; line-height:1.5em;}
.main-contact-flex .main-contact-box .more {font-size:18px; font-weight:700; color:#333; letter-spacing:-.03em; line-height:1.3em; margin-top:230px; display:flex;}
.main-contact-flex .main-contact-box .more span {margin-left:12px; vertical-align:middle;}
.main-contact-flex .main-contact-list {transition: all 1s ease-out 0s; position:relative; right:-70px; opacity:0;}
.section.main-contact.active .main-contact-flex .main-contact-list {opacity:1; right:0;}
.main-contact-flex .main-contact-list ul {display:flex;}
.main-contact-flex .main-contact-list ul li {}
.main-contact-flex .main-contact-list ul li:first-child {margin-top:25px;}
.main-contact-flex .main-contact-list ul li .box {background:#d21d4f; color:#fff;}
.main-contact-flex .main-contact-list ul li .box a {display:flex; flex-direction:column; justify-content:space-between; min-height:295px; padding:40px 30px;}
.main-contact-flex .main-contact-list ul li:last-child .box {background:#454545;}
.main-contact-flex .main-contact-list ul li .box .box-wrap {}
.main-contact-flex .main-contact-list ul li .box .box-wrap .ico {margin-bottom:25px;}
.main-contact-flex .main-contact-list ul li .box .box-wrap .tit {font-size:20px; letter-spacing:-.03em; font-weight:800; margin-bottom:12px;}
.main-contact-flex .main-contact-list ul li .box .box-wrap .txt {}
.main-contact-flex .main-contact-list ul li .box .box-wrap .txt {}
.main-contact-flex .main-contact-list ul li .box .more {display:block; text-align:right; font-size:14px; font-weight:700; letter-spacing:-.03em;}

/* sub page */
#wrapper {overflow:hidden;} 

#sub .con-flex {display:flex; max-width:1600px; margin:0 auto;}

.sub-lnb {min-width:auto; z-index:50; margin-right:100px; margin-left:30px; white-space:nowrap;}
#contArea {width:1%; flex:1 1 auto; }

/* sub */
.sub-visual {position:relative; text-align:center; height:570px; color:#fff; overflow:hidden; background:#333;}
.sub-visual .bg {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; transition:2s; transform:scale(1.1); background-repeat:no-repeat; background-position:50% 0; background-size:cover;}
.sub-visual .inner {position:absolute; top:50%; left:0; width:100%; transform:translateY(-50%);} 
.inner-wrap {width:100%; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
.sub-visual h2 {font-size:64px; font-weight:600; text-align:left;line-height:1.3em; letter-spacing:-.03em;}
.sub-visual .bg1 {background-image:url("../images/common/sv1.jpg");}
.sub-visual .bg2 {background-image:url("../images/common/sv2.jpg");}
.sub-visual .bg3 {background-image:url("../images/common/sv3.jpg");}
.sub-visual .bg4 {background-image:url("../images/common/sv4.jpg");}
.sub-visual .bg5 {background-image:url("../images/common/sv5.jpg");}
.sub-visual [data-aos=fade-up] {transform: translate3d(0,20px,0);}
.loaded .sub-visual .bg {transform:scale(1); opacity:1;}

.lnb {margin-top:-70px; position:relative; z-index:2; background:rgba(210, 29, 79, 0.8); margin-bottom:100px;}
.lnb ul {display:flex;}
.lnb ul li {position:relative; width:auto; height:70px; line-height:70px; text-align:center; letter-spacing:-.04em;}
.lnb ul li a {display:block; position:relative; font-size:20px; color:#fff; opacity:0.5; letter-spacing:-.03em; font-weight:500; padding:0 30px;} 
.lnb ul li:before {position:absolute; content:""; width:5px; height:5px; background:#fff; top:50%; border-radius:50%; margin-top:-2.5px; right:0;}
.lnb ul li:last-child:before {display:none;}
.lnb ul li:first-child a {padding-left:0;}
.lnb ul li.active a {opacity:1;}

.lnb2 {width:100%; }
.lnb2 .tit {position:relative; font-size:30px; color:#333; font-weight:600; padding-left:40px; padding-bottom:15px; letter-spacing:-.03em;}
.lnb2 .tit:after {position:absolute; content:""; width:100vw; height:1px; background:#777; right:0; bottom:0;}
.lnb2 .tit:before {position:absolute; content:""; width:33px; height:31px; background:url('../images/common/sub-logo.png')50% 50% no-repeat; background-size:contain; top:0; left:0;}
.lnb2 ul {position:relative; width:100%;}
.lnb2 li {position:relative; margin:30px 0 10px; padding-bottom:20px;}
.lnb2 li .submenu.depth ul li.active:before {position:absolute; content:""; width:100%; height:2px; background:#d21d4f; left:0; bottom:1px;}
.lnb2 li .submenu.depth ul li.active:after {position:absolute; content:""; height:1px; left:-99999em; right:0; background:#ddd; bottom:0; }
.lnb2 li a:first-child {border-top:none;}
.lnb2 li a {display:block; font-weight:500; font-size:20px; color:#333; position:relative;}
.lnb2 li a:after {content:''; width:8px; height:13px; position:absolute; top:50%; margin-top:-6.5px; left:0; background-image:url('../images/common/lnb-arrow.png'); background-repeat:no-repeat; background-size:cover;}
.lnb2 li.active {margin-top:0;}
.lnb2 li.active a {color:#d21d4f; font-weight:500;}
.lnb2 li.active a:after {background-image:url('../images/common/lnb-arrow_on.png');}

.lnb2 ul.swiper-wrapper {flex-direction:column;} 

#lnb .submenu.depth2 li a {background:#fff; color:#333; border:1px solid #ddd; border-top:0; border-left:0;}
#lnb .submenu.depth2 li:first-child a {border-top:1px solid #ddd;}
#lnb .submenu.depth2 li:nth-child(n+5) a {border-left:1px solid #ddd;}
#lnb .submenu.depth2 li a:after {background-image:url('../images/common/lnb-arrow.png');}
#lnb .submenu.depth2 li:hover a {background:#050051; color:#fff; border:1px solid #050051;}
#lnb .submenu.depth2 li:hover a:after {background-image:url('../images/common/lnb-arrow_on.png');}

#lnb .submenu {position:relative; display:inline-block; top:0; right:0; padding-top:20px;}
#lnb .submenu li {margin:0; padding-bottom:0 !important;}
#lnb .submenu li:hover a {font-weight:700; color:#333;}
#lnb .submenu li:hover a.color {color:#073d88;}
#lnb .submenu ul li a:after {display:none;}
#lnb .submenu li a {line-height:2.0em; font-size:18px; font-weight:500; letter-spacing:-.03em; color:#666; border-top:0; border-left:0; margin-bottom:0;}
#lnb .submenu li a.color {font-size:16px; color:#999;}
#lnb .submenu li.active a.color {color:#073d88;}
#lnb .submenu li.active a {color:#d21d4f; font-weight:500;}

#lnb .submenu.depth2 li a {background:#fff; color:#333; border:1px solid #ddd; border-top:0; border-left:0;}
#lnb .submenu.depth2 li:first-child a {border-top:1px solid #ddd;}
#lnb .submenu.depth2 li:nth-child(n+5) a {border-left:1px solid #ddd;}
#lnb .submenu.depth2 li a:after {background-image:url('../images/common/lnb-arrow.png');}
#lnb .submenu.depth2 li:hover a {background:#050051; color:#fff; border:1px solid #050051;}
#lnb .submenu.depth2 li:hover a:after {background-image:url('../images/common/lnb-arrow_on.png');}

.lnb-m {display:none; position:relative; margin-top:20px; margin-bottom:20px; z-index:50;}
.lnb-m .tit {display:block; position:relative; color:#fff; font-size:16px; font-weight:500; line-height:1.5em; padding:10px 40px 10px 16px; background: rgba(210, 29, 79, 0.8);}
.lnb-m .tit:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:12px; height:12px; border-right:2px solid #fff; border-bottom:2px solid #fff;}
.lnb-m > ul {display:none; position:absolute; left:0; width:100%; border:1px solid #dfdfdf; border-top:0; background:#fafafa;}
.lnb-m > ul > li {border-top:1px solid #dfdfdf;}
.lnb-m > ul > li.only-mobile {display:block !important;}
.lnb-m > ul > li:first-child {border-top:0;}
.lnb-m > ul > li > a {display:block; padding:12px 15px; font-size:15px; font-weight:500; line-height:1.4em; letter-spacing:-.04em;}
.lnb-m > ul > li.active > a {color:rgba(210, 29, 79, 0.8); font-weight:700;}
.lnb-m.active .tit:after {transform:translateY(-35%) rotate(-135deg);}
.lnb-m .submenu.depth {background:rgba(210, 29, 79, 0.1); padding:10px 20px;}

#contArea { max-width:1580px; margin:0 auto; padding-right:30px; position:relative;}
div#contArea\ wide {width:100%; max-width:none;} 

.sub-title {margin-bottom:30px; text-align:left;}
.sub-title h2 {position:relative; color:#242424; font-size:30px; line-height:1.0em; font-weight:700; letter-spacing:0; padding-left:15px;}
.sub-title h2:before {position:absolute; content:""; width:5px; height:30px; background:#3fb1e5; top:0; left:0;}

#contArea {max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}
#contArea.wide .sub-title {padding-left:10px; padding-right:10px;}
  

.real-cont {padding-bottom:120px;}
.real-cont.none {padding-bottom:0;}

/* footer */

.footer .fp-tableCell {height:auto !important;} 

#footer {clear:both; position:relative; font-size:15px; font-weight:400; line-height:1.571em; letter-spacing:-.03em; border-top:1px solid #ddd;   color:rgba(255, 255, 255, 0.6); text-align:center;}
#footer .contain {display:flex; max-width:1780px; justify-content:space-between; align-items:center;}
#footer .contain:after {display:none;}
#footer .contain .foot-addr .f-logo {margin-bottom:40px; text-align:left;}
#footer .contain .foot-addr dl dd {text-align:left;}
#footer .contain .foot-addr dl {display:flex; font-size:15px; color:#f1f1f1; margin-bottom:10px;}
#footer .contain .foot-addr dl dt {font-size:15px; letter-spacing:-.03em; min-width:90px; text-align:left;}
#footer .addr-flex {order:2;}
#footer .foot-lnb-wrap {display:flex; margin-right:-50px;}
#footer .foot-lnb {margin-right:70px; text-align:left;}
#footer .foot-lnb .tit {font-size:15px; font-weight:700; color:#fff; letter-spacing:-.03em; margin-bottom:15px;}
#footer .foot-lnb ul li {line-height:2.0em; color:#fff;}
#footer .footer-bg {background:#242424; padding:40px 0 30px;} 

.foot-link-flex {display:flex;}
.foot-link {padding:15px 0;}
.foot-link ul {display:flex;}
.foot-link ul li {margin-right:30px; color:#979797; font-size:15px;} 

.foot-menu {margin-top:40px;}
.foot-menu ul {display:flex;}
.foot-menu ul li {font-size:15px; color:#979797; letter-spacing:-.03em; padding-right:30px;} 
 
#footer address {order:2; display:flex; flex-direction:column; justify-content:center; color:#979797; letter-spacing:-.03em; font-style:normal;} 
#footer address span a {color:#777; margin-left:25px;}

.fp-auto-height {height:auto !important;}

.go-top {position:absolute; right:100px; bottom:83px;}

.familysite {position:relative; display:inline-block; width:160px; text-align:left; font-size: 15px;}
.familysite .toggle-button {display:flex; justify-content:space-between; align-items:center; border:0; width:100%; padding:8px 15px; background:#eee; color:#2c2c2c; font-weight:500; line-height:1.5em;}
.familysite .toggle-button .txt {width:36px;color: #777;}
.familysite .toggle-button .chevron {width:12px;}
.familysite .toggle-button svg {display:block; width:100%; height:auto;}
.familysite .toggle-button path {fill:#777;}
.familysite .toggle-layer {display:none; position:absolute; left:0; bottom:100%; width:100%; background:#eee;}
.familysite .toggle-layer a {display:block; padding:8px 15px; color:#777; font-weight:400; line-height:1.5em;}
.familysite .toggle-layer a:hover {background:#f7f7f7; color:#2c2c2c;}
.familysite.active .toggle-button .chevron {transform:scaleY(-1);}