@font-face { font-family: 'NanumSquare'; font-weight: 400; src: url("../fonts/NanumSquareR.eot"); src: url("../fonts/NanumSquareR.eot?#iefix") format("embedded-opentype"), url("../fonts/NanumSquareR.woff2") format("woff2"), url("../fonts/NanumSquareR.woff") format("woff"); }

@font-face { font-family: 'NanumSquare'; font-weight: 700; src: url("../fonts/NanumSquareB.eot"); src: url("../fonts/NanumSquareB.eot?#iefix") format("embedded-opentype"), url("../fonts/NanumSquareB.woff2") format("woff2"), url("../fonts/NanumSquareB.woff") format("woff"); }

.fsm22 { font-size: 0.938rem; }

@media screen and (min-width: 1024px) { .fsm22 { font-size: 1.375rem; } }

.fsm24 { font-size: 1rem; }

@media screen and (min-width: 1024px) { .fsm24 { font-size: 1.5rem; } }

.ptxt1 { font-size: 0.875rem; color: #333; font-weight: 700; }

@media screen and (min-width: 1024px) { .ptxt1 { font-size: 1.125rem; } }

.txtdeco_under { text-decoration: underline; }

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; /*vertical-align:baseline;*/ -webkit-box-sizing: border-box; box-sizing: border-box; }

body, th, td, input, select, textarea, button { font-size: 100%; line-height: 1.5; font-family: "NanumSquare", sans-serif; color: #555; font-weight: 400; letter-spacing: -0.5px; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main { display: block; }

body { -webkit-text-size-adjust: none; }

h1, h2, h3, h4, h5, h6 { font-size: 1rem; font-weight: 700; }

ol, ul, li, dl, dt, dd { list-style: none outside none; padding: 0; margin: 0; }

hr { display: none; }

span { margin: 0; padding: 0; outline: 0; }

fieldset, img, table, caption, tbody, tfoot, thead, tr, th, td, button, hr { border: 0; }

address, caption, cite, code, dfn, em, strong, th, var { font-style: normal; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }

table { border-collapse: separate; border-spacing: 0; width: 100%; }

img { vertical-align: middle; }

a { text-decoration: none; cursor: pointer; color: #555; }

a:active, a:hover { text-decoration: none; }

input, select, label { vertical-align: middle; }

input, select, textarea, button { font-size: 1rem; vertical-align: middle; padding: 0; margin: 0; }

input, textarea { /*border-radius: 0; appearance:none; -webkit-appearance:none;*/ font-family: "NanumSquare", sans-serif; }

button, input[type='text'], input[type='password'], input[type='tel'], input[type='num'], input[type='button'], input[type='submit'], input[type='reset'], input[type='file'] { 
    -webkit-appearance: button; 
    appearance: button; 
    border-radius: 0; 
}

input[type='search']::-webkit-search-cancel-button { 
    -webkit-appearance: none; 
    appearance: none;
}

textarea { resize: none; }

button { border: 0 none; background-color: transparent; cursor: pointer; vertical-align: middle; }

b, strong { font-weight: 700; }

input[type="text"], input[type="password"], input[type="number"], input[type="tel"], input[type="email"], input[type="search"] { -webkit-box-sizing: border-box; box-sizing: border-box; }

/* ie Control */
input::-ms-clear { display: none; }

/* SkipNavigation */
#skipNavigation { position: absolute; width: 100%; top: -200px; left: 0; margin: 0 auto; z-index: 9999; }

#skipNavigation a { display: block; height: 35px; background-color: #1c80cc; color: #fff; text-align: center; }

#skipNavigation a:active, #skipNavigation a:focus { position: absolute; left: 0; top: 200px; width: 100%; color: #fff; background: #1c80cc; line-height: 35px; text-align: center; border-bottom: 1px solid #dbdbdb; font-size: 16px; }

.clearfix::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }

caption { visibility: hidden; overflow: hidden; width: 0; height: 0; padding: 0; margin: 0; }

legend, .blind { position: absolute; left: -9999px; top: 0; height: 0; font-size: 1px; line-height: 0; text-indent: -9999em; overflow: hidden; }

#wrap { width: 100%; overflow: hidden; }

#contents { position: relative; width: 100%; }

.subwrapper #contents { padding-top: 50px; }

@media screen and (min-width: 1024px) { .subwrapper #contents { padding-top: 100px; } }

.isico { display: block; background-image: url("../images/common/is_ico.png"); background-size: 320px auto; background-repeat: no-repeat; text-indent: -9999em; overflow: hidden; }

@media screen and (min-width: 1024px) { .isico { background-size: auto; } }

.isico.isi_more { width: 13px; height: 13px; background-position: 0 0; }

@media screen and (min-width: 1024px) { .isico.isi_more { width: 26px; height: 26px; background-position: 0 0; } }

.isico.isi_down { width: 6px; height: 6px; background-position: -14px 0; }

@media screen and (min-width: 1024px) { .isico.isi_down { width: 12px; height: 12px; background-position: -28px 0; } }

.isico.isi_top { width: 9px; height: 13px; background-position: -21px 0; }

@media screen and (min-width: 1024px) { .isico.isi_top { width: 18px; height: 26px; background-position: -42px 0; } }

.bggray { background-color: #efefef; }

.mgt15 { margin-top: 7.5px; }

@media screen and (min-width: 1024px) { .mgt15 { margin-top: 15px; } }

.mgb10 { margin-bottom: 5px; }

@media screen and (min-width: 1024px) { .mgb10 { margin-bottom: 10px; } }

.mgb15 { margin-bottom: 7.5px; }

@media screen and (min-width: 1024px) { .mgb15 { margin-bottom: 15px; } }

.mgb20 { margin-bottom: 10px; }

@media screen and (min-width: 1024px) { .mgb20 { margin-bottom: 20px; } }

.mgb90 { margin-bottom: 45px; }

@media screen and (min-width: 1024px) { .mgb90 { margin-bottom: 90px; } }

@-webkit-keyframes scrollBounce { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-50%, 10px); transform: translate(-50%, 10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

@keyframes scrollBounce { 0% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
  50% { -webkit-transform: translate(-50%, 10px); transform: translate(-50%, 10px); }
  100% { -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); } }

@-webkit-keyframes keyMent01 { 0% { opacity: 0;
    -webkit-transform: translateY(80px);
            transform: translateY(80px); }
  20% { opacity: 0; }
  100% { opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px); } }

@keyframes keyMent01 { 0% { opacity: 0;
    -webkit-transform: translateY(80px);
            transform: translateY(80px); }
  20% { opacity: 0; }
  100% { opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px); } }

@-webkit-keyframes keyMent02 { 0% { opacity: 0;
    -webkit-transform: translateY(-60px);
            transform: translateY(-60px); }
  20% { opacity: 0; }
  100% { opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0); } }

@keyframes keyMent02 { 0% { opacity: 0;
    -webkit-transform: translateY(-60px);
            transform: translateY(-60px); }
  20% { opacity: 0; }
  100% { opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0); } }

/* ========================================================================= */
/* Main Header Styles */
/* ========================================================================= */

.main-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    background: url("../images/common/top-bg.png") no-repeat center top;
    background-size: 1920px 130px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.main-header .inner {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
}

/* 1행: Utility */
.header-util {
    height: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.2);
}

.header-util .inner {
    justify-content: space-between;
}

.accessibility-tools {
    display: flex;
    gap: 25px;
}

.accessibility-tools button {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #fff;
    font-size: 14px;
}

.header-util .util-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.util-item {
    color: #fff;
    font-size: 14px;
}

.user-info {
    color: #fff;
    font-size: 14px;
}

.lang-select {
    position: relative;
}

.btn-lang {
    color: #fff;
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 14px;
}

.lang-list {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    background: #fff;
    border: 1px solid #ddd;
    min-width: 80px;
}

/* 2행: Main */
.header-main {
    height: 90px;
}

.header-main .logo a {
    display: block;
}

/* GNB */
.gnb {
    flex: 1;
}

.gnb-list {
    display: flex;
    justify-content: center;
}

.gnb-item {
    position: relative;
    padding: 0 30px;
}

.gnb-link {
    display: block;
    line-height: 90px;
    font-size: 18px;
    font-weight: 700;
    color: #333;
    position: relative;
    transition: color 0.3s;
}

/* GNB Hover Effect */
.gnb-item:hover .gnb-link,
.gnb-item.active .gnb-link {
    color: #442c93;
}

.gnb-item .gnb-link::after {
    content: '';
    position: absolute;
    bottom: 25px; /* 조정 가능 */
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 3px;
    background-color: #442c93;
    transition: width 0.3s;
}

/* Underline logic from spec: 4px wider than text, 12px gap from text */
.gnb-item:hover .gnb-link::after,
.gnb-item.active .gnb-link::after {
    width: calc(100% + 4px);
}

/* Sub Menu (Mega Menu style) */
.sub-menu {
    display: none;
    position: absolute;
    top: 90px;
    left: 0;
    width: 100vw;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border-top: 1px solid #eee;
    box-shadow: 0 5px 10px rgba(0,0,0,0.05);
    padding: 20px 0;
}

.sub-menu ul {
    display: flex;
    justify-content: center;
    gap: 40px;
}

.sub-menu a {
    color: #666;
    font-size: 16px;
    transition: color 0.2s;
}

.sub-menu a:hover {
    color: #442c93;
    text-decoration: underline;
}

/* Actions */
.header-actions {
    display: flex;
    align-items: center;
    gap: 15px;
}

.btn-all-menu {
    width: 30px;
    height: 24px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.hamburger-bar {
    display: block;
    width: 100%;
    height: 2px;
    background: #333;
}

/* Accessibility Modes */
.high-contrast {
    filter: invert(100%) hue-rotate(180deg);
    background-color: #000 !important;
}
.high-contrast img, 
.high-contrast video, 
.high-contrast iframe,
.high-contrast [style*="background-image"],
.high-contrast .main-header {
    filter: invert(100%) hue-rotate(180deg);
}

.font-size-up {
    font-size: 110%; /* rem/em 기반일 때 효과적 */
}
.font-size-up body,
.font-size-up p,
.font-size-up li,
.font-size-up a,
.font-size-up button {
    font-size: 1.15em !important;
}

/* Responsive */
@media screen and (max-width: 1024px) {
    .header-util { display: none; }
    .header-main { height: 60px; }
    .gnb { display: none; }
    .header-main .logo img { width: 160px; height: auto; }
}

.main { width: 100%; }

.main .visual { position: relative; height: 100vh; text-align: center; }

.main .visual .mainslider { position: relative; height: 100%; }

.main .visual .mainslider .item { height: 100vh; background-size: cover; background-position: center; }

/* .main .visual .mainslider .item.vis01 { background-image: url("../images/main/main_visual01.jpg"); } */

/* .main .visual .mainslider .item.vis02 { background-image: url("../images/main/main_visual02.jpg"); } */

/* .main .visual .mainslider .item.vis03 { background-image: url("../images/main/main_visual03.jpg"); } */
/* .main .visual .mainslider .item.vis04 { background-image: url("../images/main/main_visual04.jpg"); } */
/* .main .visual .mainslider .item.vis05 { background-image: url("../images/main/main_visual05.jpg"); } */

.main .visual .keyment { position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 90%; }

.main .visual .keyment h2 { color: #fff; margin-bottom: 5px; font-size: 2rem; font-weight: 700; -webkit-animation-name: keyMent01; animation-name: keyMent01; -webkit-animation-duration: 2s; animation-duration: 2s; -webkit-animation-iteration-count: 1; animation-iteration-count: 1; -webkit-animation-fill-mode: backwards; animation-fill-mode: backwards; z-index: 2; }

.main .visual .keyment p { color: #f26532; -webkit-animation-name: keyMent02; animation-name: keyMent02; -webkit-animation-duration: 2s; animation-duration: 2s; -webkit-animation-iteration-count: 1; animation-iteration-count: 1; -webkit-animation-delay: 0.4s; animation-delay: 0.4s; -webkit-animation-fill-mode: backwards; animation-fill-mode: backwards; }

.main .visual .scrolldown { position: absolute; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); display: block; bottom: 20px; -webkit-animation-name: scrollBounce; animation-name: scrollBounce; -webkit-animation-duration: 1.5s; animation-duration: 1.5s; -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; z-index: 2; }

.main .visual .scrolldown::before { content: ''; display: block; margin: 0 auto 3px; width: 13px; height: 20px; background: url("../images/main/scroll.png") no-repeat; background-size: contain; }

.main .visual .scrolldown p { font-size: 0.688rem; color: #fff; }

.mainsector { padding: 60px 0 70px; }

.mainsector.mainsect_clr1 { background-color: #efefef; }

.mainsector.mainsect_bg1 { background: url("../images/main/sect_bg.gif") no-repeat; background-size: cover; }

.mainsector .sectit { position: relative; margin-bottom: 40px; font-size: 2.188rem; color: #141414; text-align: center; }

.mainsector .sectit::after { content: ''; display: block; position: absolute; left: 50%; width: 1px; height: 15px; bottom: -15px; background-color: #141414; }

.mainsector .servicelist { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -ms-flex-pack: distribute; justify-content: space-around; margin-bottom: 35px; }

.mainsector .servicelist li { width: 48%; margin-bottom: 40px; text-align: center; }

.mainsector .servicelist li a { display: block; }

.mainsector .servicelist li .item { margin-left: auto; margin-right: auto; width: 148px; }

.mainsector .servicelist li .item h4 { font-size: 0.875rem; margin-bottom: 6px; color: #333; }

@media screen and (min-width: 1024px) { .mainsector .servicelist li .item h4 { font-size: 1.125rem; } }

.mainsector .servicelist li .item p { font-size: 0.875rem; word-break: keep-all; }

@media screen and (min-width: 1024px) { .mainsector .servicelist li .item p { font-size: 1rem; } }

.mainsector .servicelist li .iconbox { height: 148px; margin-bottom: 15px; border-radius: 50%; background-size: cover; background-color: #fff; background-position: center top; }

.mainsector .servicelist li:nth-of-type(1) .iconbox { background-image: url("../images/main/maincon01.png"); }

.mainsector .servicelist li:nth-of-type(2) .iconbox { background-image: url("../images/main/maincon02.png"); }

.mainsector .servicelist li:nth-of-type(3) .iconbox { background-image: url("../images/main/maincon03.png"); }

.mainsector .servicelist li:nth-of-type(4) .iconbox { background-image: url("../images/main/maincon04.png"); }

.mainsector .servicelist li:nth-of-type(5) .iconbox { background-image: url("../images/main/maincon05.png"); }

@media screen and (min-width: 768px) { .mainsector .servicelist li { width: 33.3333333333333%; } }

.mainsector .portfoliolist { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -ms-flex-pack: distribute; justify-content: space-around; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; margin-bottom: 35px; }

.mainsector .portfoliolist li { width: 46%; margin-bottom: 30px; letter-spacing: -0.8px; }


.mainsector .portfoliolist li figure { display: block; margin-bottom: 10px; border: 1px solid #efefef; }

.mainsector .portfoliolist li figure img { width: 100%; }

.mainsector .portfoliolist li figcaption { margin-bottom: 5px; font-weight: 700; color: #333; font-size: 0.875rem; }

@media screen and (min-width: 1024px) { .mainsector .portfoliolist li figcaption { font-size: 1.125rem; } }

.mainsector .portfoliolist li p { font-size: 0.875rem; word-break: break-all; }

@media screen and (min-width: 1024px) { .mainsector .portfoliolist li p { font-size: 1rem; } }

.mainsector .portfoliolist li p span { text-decoration: underline; }

.mainsector .locarea { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-bottom: 30px; background-color: #fff; }

.mainsector .locarea .maparea { width: 100%; height: 233px; }

.mainsector .locarea .loc_infolist { width: 90.90909%; padding: 20px 0; margin-left: auto; margin-right: auto; }

.mainsector .locarea .loc_infolist li { width: 100%; margin-top: 15px; }

.mainsector .locarea .loc_infolist li::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }

.mainsector .locarea .loc_infolist li:first-of-type { margin-top: 0; }

.mainsector .locarea .loc_infolist li .icoinfo { float: left; width: 45px; height: 45px; background-color: #e0e0e0; border-radius: 50%; background-size: cover; }

.mainsector .locarea .loc_infolist li .txinfo { width: auto; margin-left: 65px; }

.mainsector .locarea .loc_infolist li .txinfo h4 { margin-bottom: 6px; color: #333; font-size: 0.875rem; }

@media screen and (min-width: 1024px) { .mainsector .locarea .loc_infolist li .txinfo h4 { font-size: 1.125rem; } }

.mainsector .locarea .loc_infolist li .txinfo p { font-size: 0.875rem; }

@media screen and (min-width: 1024px) { .mainsector .locarea .loc_infolist li .txinfo p { font-size: 1rem; } }

.mainsector .locarea .loc_infolist li:nth-of-type(1) .icoinfo { background-image: url("../images/main/locaicon01.png"); }

.mainsector .locarea .loc_infolist li:nth-of-type(2) .icoinfo { background-image: url("../images/main/locaicon02.png"); }

.mainsector .locarea .loc_infolist li:nth-of-type(3) .icoinfo { background-image: url("../images/main/locaicon03.png"); }

.mainsector .locarea .loc_infolist li .download { display: inline-block; vertical-align: middle; }

.mainsector .locarea .loc_infolist li .download span { display: inline-block; vertical-align: middle; padding: 6px; border: 1px solid #e0e0e0; border-radius: 50%; }

.mainsector .locarea .loc_infolist li .download .isico { margin-left: auto; margin-right: auto; }

.mainsector .locarea .loc_infolist li .download + .download { margin-left: 8px; }

@media screen and (min-width: 768px) { .mainsector .portfoliolist { -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .mainsector .portfoliolist li { width: 23.08333%; }
  .mainsector .locarea { -webkit-box-orient: horizontal; -webkit-box-direction: normal; -ms-flex-direction: row; flex-direction: row; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: stretch; -ms-flex-align: stretch; align-items: stretch; margin-block: 60px; }
  .mainsector .locarea .maparea { width: 54.16667%; height: 350px; }
  .mainsector .locarea .infoarea { width: 45.83333%; }
  .mainsector .locarea .infoarea .loc_infolist { display: table; height: 100%; padding: 30px 0; }
  .mainsector .locarea .infoarea .loc_infolist li { display: table-row; vertical-align: middle; } }

@media screen and (min-width: 1024px) { .main .visual .keyment h2 { margin-bottom: 10px; font-size: 5rem; }
  .main .visual .keyment p { font-size: 2.125rem; }
  .main .visual .scrolldown { bottom: 40px; }
  .main .visual .scrolldown::before { margin-bottom: 10px; width: 26px; height: 40px; }
  .main .visual .scrolldown p { font-size: 0.875rem; }
  .mainsector { padding: 120px 0 150px; }
  .mainsector .sectit { margin-bottom: 80px; font-size: 4.375rem; }
  .mainsector .sectit::after { height: 30px; bottom: -30px; }
  .mainsector .servicelist { margin-bottom: 95px; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .mainsector .servicelist li { width: 188px; margin-bottom: 0; }
  .mainsector .servicelist li .item { width: 188px; }
  .mainsector .servicelist li .item h4 { margin-bottom: 15px; }
  .mainsector .servicelist li:first-of-type .item { margin-left: 0; }
  .mainsector .servicelist li .iconbox { height: 188px; margin-bottom: 35px; }
  .mainsector .servicelist li a:hover .iconbox { background-color: #f26532; background-position: center bottom; }
  .mainsector .portfoliolist li { margin-bottom: 50px; }
  .mainsector .locarea .maparea { height: 466px; }
  .mainsector .locarea .infoarea .loc_infolist { padding: 45px 0; }
  .mainsector .locarea .infoarea .loc_infolist li { margin-top: 25px; }
  .mainsector .locarea .infoarea .loc_infolist li .icoinfo { width: 90px; height: 90px; }
  .mainsector .locarea .infoarea .loc_infolist li .txinfo { margin-left: 130px; }
  .mainsector .locarea .infoarea .loc_infolist li .txinfo h4 { margin-bottom: 12px; }
  .mainsector .locarea .infoarea .loc_infolist li .download + .download { margin-left: 16px; } }

@media screen and (min-width: 1440px) { .mainsector .servicelist li { width: 216px; }
  .mainsector .servicelist li .item { width: 216px; }
  .mainsector .servicelist li .iconbox { height: 216px; } }

.hinner { position: relative; width: 95%; max-width: 1540px; margin-left: auto; margin-right: auto; }

.inner { position: relative; width: 95%; max-width: 1200px; margin-left: auto; margin-right: auto; }

.sector { padding: 60px 0 70px; }

@media screen and (min-width: 1024px) { .sector { padding: 120px 0 200px; } }

.sector2 { padding: 60px 0; }

@media screen and (min-width: 1024px) { .sector2 { padding: 120px 0 125px; } }

.sectit1 { font-size: 2.188rem; color: #141414; text-align: center; }

@media screen and (min-width: 1024px) { .sectit1 { font-size: 4.375rem; } }

.smallst { font-size: 0.938rem; text-align: center; }

@media screen and (min-width: 1024px) { .smallst { font-size: 1.375rem; } }

.ulist1 > li { font-size: 0.875rem; position: relative; padding-left: 9px; margin-top: 6px; }

@media screen and (min-width: 1024px) { .ulist1 > li { font-size: 1rem; } }

.ulist1 > li::before { background-color: #f26532; content: ''; display: block; position: absolute; width: 2px; height: 2px; top: 7px; left: 0; }

.ulist1 > li:first-of-type { margin-top: 0; }

@media screen and (min-width: 1024px) { .ulist1 > li::before { width: 3px; height: 3px; top: 9px; } }

.more { position: absolute; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); font-size: 0.875rem; text-align: center; color: #141414; }

@media screen and (min-width: 1024px) { .more { font-size: 1rem; } }

.more .isico { margin-left: auto; margin-right: auto; margin-bottom: 3px; }

@media screen and (min-width: 1024px) { .more .isico { margin-bottom: 5px; } }

.ovw .visual { background: url("../images/sub/visual_overview.jpg") no-repeat center; background-size: cover; }

.ovw .keyment { margin-bottom: 50px; }

@media screen and (min-width: 1024px) { .ovw .keyment { margin-bottom: 100px; } }

.visinfo { text-align: center; }

.visinfo > div { display: inline-block; vertical-align: middle; margin-bottom: 30px; }

.visinfo > div img { max-width: 80%; }

@media screen and (min-width: 768px) { .visinfo > div img { max-width: 100%; } }

@media screen and (min-width: 1024px) { .visinfo > div { margin-bottom: 0; }
  .visinfo > div + div { margin-left: 110px; } }

.sub .visual { position: relative; text-align: center; padding: 70px 15px 80px; }

.sub .keyment h2 { margin-bottom: 10px; font-size: 2.188rem; color: #fff; }

@media screen and (min-width: 1024px) { .sub .keyment h2 { margin-bottom: 20px; } }

@media screen and (min-width: 1024px) { .sub .keyment h2 { font-size: 4.375rem; } }

.sub .keyment p { font-size: 0.938rem; color: #fff; }

@media screen and (min-width: 1024px) { .sub .keyment p { font-size: 1.375rem; } }

.sub .keyment p > strong { font-size: 1rem; display: block; margin-bottom: 10px; }

@media screen and (min-width: 1024px) { .sub .keyment p > strong { font-size: 1.5rem; } }

.history { position: relative; padding: 30px 0 40px; }

.history > li { position: relative; padding-left: 40px; margin-bottom: 25px; }

.history > li h4 { font-size: 1.375rem; color: #f26532; }

@media screen and (min-width: 1024px) { .history > li h4 { font-size: 2rem; } }

.history > li::before { background-color: #ccc; content: ''; display: block; position: absolute; width: 23px; height: 1px; top: 15px; left: 0; z-index: 2; }

.history > li::after { background-color: #f26532; content: ''; display: block; position: absolute; width: 6px; height: 6px; top: 13px; left: -3px; border-radius: 50%; z-index: 3; }

.history::before { background-color: #ccc; content: ''; display: block; position: absolute; width: 1px; height: 100%; top: 0; left: 0; z-index: 1; }

@media screen and (min-width: 1024px) { .sub .visual { padding: 130px 0 160px; }
  .history { padding: 60px 0 65px; }
  .history::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }
  .history > li { float: right; width: 50.005%; padding-left: 82px; margin-bottom: 25px; }
  .history > li h4 { margin-bottom: 10px; }
  .history > li::before { width: 55px; top: 22px; }
  .history > li::after { width: 9px; height: 9px; top: 18px; left: -4px; }
  .history > li:nth-of-type(even) { float: left; padding-left: 0; padding-right: 82px; }
  .history > li:nth-of-type(even)::before { left: auto; right: 0; }
  .history > li:nth-of-type(even)::after { left: auto; right: -4px; }
  .history::before { left: 50%; } }

.service > li { margin-top: 50px; }

.service > li:first-of-type { margin-top: 0; }

.service > li .thumb { position: relative; z-index: 3; }

.service > li .thumb img { width: 100%; }

.service > li .box { background-color: #fff; position: relative; padding: 20px 20px 25px; z-index: 2; }

.service > li .box h4 { font-size: 1.5rem; color: #f26532; margin-bottom: 15px; }

@media screen and (min-width: 1024px) { .service > li .box h4 { font-size: 2.125rem; } }

.service > li .line { display: none; }

@media screen and (min-width: 768px) { .service > li { position: relative; margin-top: 80px; }
  .service > li::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }
  .service > li .thumb { position: absolute; width: 338px; height: 234px; top: -20px; left: 0; }
  .service > li .box { position: relative; float: right; width: 72%; max-width: 864px; padding: 35px 35px 35px 23%; }
  .service > li .line { display: block; position: absolute; width: 75%; height: 1px; top: 98px; right: 25px; background-color: #f26532; opacity: 0.3; z-index: 5; }
  .service > li:nth-of-type(even) .thumb { left: auto; right: 0; }
  .service > li:nth-of-type(even) .box { float: left; padding-right: 23%; padding-left: 35px; }
  .service > li:nth-of-type(even) .line { left: 25px; right: auto; } }

@media screen and (min-width: 1024px) { .service > li { margin-top: 128px; }
  .service > li .thumb { width: 570px; height: 395px; top: -30px; }
  .service > li .box { width: 63.75%; max-width: 765px; padding: 75px 80px 75px 24.5%; }
  .service > li .box h4 { margin-bottom: 50px; }
  .service > li .line { width: 63%; top: 172px; right: 80px; }
  .service > li:nth-of-type(even) .thumb::after { left: auto; right: 50%; margin-left: 0; margin-right: 45px; }
  .service > li:nth-of-type(even) .box { padding-right: 24.5%; padding-left: 80px; }
  .service > li:nth-of-type(even) .line { left: 80px; } }

@media screen and (min-width: 1260px) { .service > li .box { padding-left: 210px; padding-right: 150px; }
  .service > li:nth-of-type(even) .box { padding-left: 150px; padding-right: 210px; } }

.portlist::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }

.portlist > li { float: left; width: 46%; margin-bottom: 15px; }

.portlist > li > a, .portlist > li > div { background-color: #fff; display: block; }

.portlist > li figure { border-bottom: 1px solid #ddd; }

.portlist > li figure img { width: 100%; }

.portlist > li .figcap { font-size: 0.875rem; padding: 12px 12px 18px; word-break: break-all; }

@media screen and (min-width: 1024px) { .portlist > li .figcap { font-size: 1rem; } }

.portlist > li .figcap h4 { font-size: 0.875rem; color: #333; margin-bottom: 5px; }

@media screen and (min-width: 1024px) { .portlist > li .figcap h4 { font-size: 1rem; } }

.portlist > li .figcap .playstore { display: inline-block; vertical-align: middle; background-color: #f26532; color: #fff; padding: 4px 12px; line-height: 1; font-size: 0.813rem; border-radius: 10px; }

.portlist > li .figcap .playstore::after { content: 'Playstore >'; display: block; }

@media screen and (max-width: 767px) { .portlist > li:nth-of-type(even) { float: right; }
  .portlist > li:nth-of-type(2n+1) { clear: both; } }

@media screen and (min-width: 768px) { .portlist > li { width: 33.33333%; }
  .portlist > li > a, .portlist > li > div { margin-left: auto; margin-right: auto; width: 94%; max-width: 380px; }
  .portlist > li:nth-of-type(3n+1) { clear: both; } }

@media screen and (min-width: 1024px) { .portlist { margin-left: -1.1%; margin-right: -1.1%; }
  .portlist > li { margin-bottom: 30px; }
  .portlist > li .figcap { font-size: 0.875rem; padding: 24px 24px 28px; } }

@media screen and (min-width: 1024px) and (min-width: 1024px) { .portlist > li .figcap { font-size: 1rem; } }

@media screen and (min-width: 1024px) { .portlist > li .figcap h4 { margin-bottom: 10px; } }

.submaparea { margin-bottom: 35px; width: 100%; height: 233px; }

@media screen and (min-width: 1024px) { .submaparea { margin-bottom: 70px; } }

@media screen and (min-width: 1024px) { .submaparea { height: 466px; } }

.locinfo { margin-left: auto; margin-right: auto; width: 90.90909%; }

.locinfo > li { width: 100%; margin-top: 15px; }

.locinfo > li::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }

.locinfo > li:first-of-type { margin-top: 0; }

.locinfo > li .icoinfo { float: left; width: 71px; height: 71px; background-size: contain; background-repeat: no-repeat; }

.locinfo > li .icoinfo.ico1 { background-image: url("../images/sub/icon_loc01.png"); }

.locinfo > li .icoinfo.ico2 { background-image: url("../images/sub/icon_loc02.png"); }

.locinfo > li .icoinfo.ico3 { background-image: url("../images/sub/icon_loc03.png"); }

@media screen and (min-width: 1024px) { .locinfo > li .icoinfo { width: 142px; height: 142px; } }

.locinfo > li .txinfo { width: auto; margin-left: 90px; }

@media screen and (min-width: 1024px) { .locinfo > li .txinfo { margin-left: 170px; } }

.locinfo > li .txinfo h4 { font-size: 0.875rem; color: #333; margin-bottom: 5px; font-weight: 700; }

@media screen and (min-width: 1024px) { .locinfo > li .txinfo h4 { font-size: 1.125rem; } }

.locinfo > li .txinfo p { font-size: 0.875rem; }

@media screen and (min-width: 1024px) { .locinfo > li .txinfo p { font-size: 1rem; } }

@media screen and (min-width: 768px) { .locinfo.midfo::after { content: ''; display: block; float: none; clear: both; height: 0; font-size: 0; line-height: 0; visibility: hidden; }
  .locinfo.midfo > li { float: left; width: 49%; margin-top: 0; }
  .locinfo.midfo > li:nth-child(even) { float: right; } }

.sector_rec { position: relative; padding: 65px 2.5%; color: #fff; background: url("../images/sub/visual_recruit.jpg") no-repeat center; background-size: cover; text-align: center; }

@media screen and (min-width: 1024px) { .sector_rec { padding: 110px 0 130px; } }

.sector_rec h3 { font-size: 2.188rem; margin-bottom: 15px; text-align: center; }

@media screen and (min-width: 1024px) { .sector_rec h3 { font-size: 4.375rem; } }

.sector_rec .p1 { font-size: 1rem; margin-bottom: 8px; font-weight: 700; text-align: center; }

@media screen and (min-width: 1024px) { .sector_rec .p1 { font-size: 1.5rem; } }

.sector_rec .p2 { font-size: 0.938rem; text-align: center; }

@media screen and (min-width: 1024px) { .sector_rec .p2 { font-size: 1.25rem; } }

.sector_rec .locinfo { margin-top: 30px; }

@media screen and (min-width: 1024px) { .sector_rec .locinfo { margin-top: 60px; } }

.sector_rec .locinfo > li { text-align: left; }

.sector_rec .locinfo a { color: #fff; }

.sector_rec .locinfo .down { display: inline-block; vertical-align: middle; padding-right: 20px; background: url("../images/common/ico_download.png") no-repeat; background-position: right 3px; background-size: 12px auto; }

.sector_rec .locinfo .down + .down { margin-left: 5px; }

@media screen and (min-width: 768px) { .sector_rec .locinfo { display: inline-block; vertical-align: middle; width: auto; } }

@media screen and (min-width: 1024px) { .sector_rec .locinfo .down { height: 24px; padding-right: 30px; background-position: right 0; background-size: 24px auto; }
  .sector_rec .locinfo .down + .down { margin-left: 10px; } }
/*# sourceMappingURL=styles.css.map */

/* 에러페이지 */
.page-error {height:calc(100vh - 200px); display: flex; align-items: center; justify-content: center; flex-wrap: wrap;}
.page-error > .error-cont > div  {display: block; width:100%; text-align: center;}
.page-error p {width:100%; margin:20px 0 60px 0; text-align: center;}
.error-logo {text-align: center;}
.error-logo img { max-width:150px; }
.btn_st2 {background-color: #eb6120; color: #fff;}
.btn_normal {height:50px; font-size:16px; padding:0 20px;}
.btn-flex-inline {display:inline-flex; justify-content:center; align-items:center;}
.inner-wrapper {max-width: 1440px; margin:0 auto; width:100%; padding:0 15px;}
#sub-contents .sub-detail {padding-top:180px;}

@media screen and (max-width:1400px) {
	#sub-contents .sub-detail {padding-top:70px;}
}

@media screen and (max-width:767px){
    .page-error a.btn_st2 {width:100%;}
    .btn_normal {height:36px; font-size:14px; padding:0 12px;}
}

/* ========================================================================= */
/* Accessibility Modes */
/* ========================================================================= */

/* High Contrast Mode */
.high-contrast {
    filter: invert(100%) hue-rotate(180deg);
    background-color: #000;
}
.high-contrast img, 
.high-contrast video, 
.high-contrast iframe,
.high-contrast [style*="background-image"] {
    filter: invert(100%) hue-rotate(180deg);
}

/* Font Size Adjustment */
.font-size-up {
    font-size: 1.25em !important;
}