@charset "UTF-8";


/* design guide variables */
:root {
  --color-border: #e4e8eb;
  --color-point: rgba(255, 149, 0, 1);
  --color-focus: rgba(255, 149, 0, 0.2);
  --size-content-width: 1200px;
}


/* reset for mobile version */
.pc {display: none !important;}
br.only-pc {content: ''; display: none;}
br.only-pc:after {content: '\00a0';}


/* common */
html {font-family: 'Noto Sans', sans-serif; font-weight: 400; font-size: 13px; color: var(--color-text); background: #ffffff; color: #333333;}
#wrapper {overflow: hidden; min-height: 100vh; padding-top: 90px;}
#skip-nav {position: fixed; left: 0; top: -40px; width: 100%; line-height: 40px; text-align: center; font-size: 16px; color: #ffffff; background: rgba(0, 0, 0, 0.7); transition: top 0.3s; z-index: 100000;}
#skip-nav:focus {top: 0;}
#main-before {position: fixed; left: -160px; top: 90px; width: 160px; line-height: 30px; text-align: center; font-size: 14px; color: #ffffff; background-color: rgba(0, 0, 0, 0.5); transition: left 0.3s; z-index: 100000;}
#main-before:focus {left: 0;}

#header {position: fixed; left: 0; top: 0; width: 100%; background-color: #ffffff; z-index: 10000; transition: all 0.3s;}

#header-popup {position: relative; height: 0; overflow: hidden; transition: all 0.3s;}
#header-popup > div.container {display: none;}
#header-popup > div.container img {object-fit: cover; width: 100%; height: 100%;}
#header-popup span.check {position: absolute; right: 40px; bottom: 3px; line-height: 18px; padding: 0 12px; border: 1px solid rgba(255, 255, 255, 0.7); border-radius: 100px; font-size: 11px; background-color: rgba(0, 0, 0, 0.3); color: #ffffff;}
#header-popup span.check > * {vertical-align: middle; margin: 0;}
#header-popup span.check > label {display: inline-block; padding-left: 5px;}
#header-popup a.close {position: absolute; right: 0; bottom: 0; width: 24px; height: 24px; overflow: hidden; background-color: rgba(255, 255, 255, 0.7); z-index: 10;}
#header-popup a.close i {position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
#header-popup::after {content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; background-color: var(--color-border);}

#header-top {position: relative; font-size: 11px; height: 30px; border-bottom: 1px solid var(--color-border); transition: all 0.3s; z-index: 100;}
#header-top > div.container {position: relative; height: 100%; max-width: var(--size-content-width); margin: 0 auto;}
#header-top .user {position: absolute; left: 15px; top: 50%; transform: translate(0, -50%); color: #888888; line-height: 24px;}
#header-top .user span.photo {display: inline-block; vertical-align: top; width: 24px; height: 24px; border-radius: 30px; border: 1px solid var(--color-border); overflow: hidden; margin-right: 3px;}
#header-top .user span.photo imag {object-fit: cover; width: 100%; height: 100%;}
#header-top a.menu-top {position: absolute; right: 55px; top: -30px; width: 34px; height: 34px; font-size: 20px; color: #999999; transition: all 0.3s; display: none;}
#header-top ul.top-menu {position: absolute; right: 0; display: inline-flex; line-height: 29px; color: #888888;}
#header-top ul.top-menu > li:first-child {border-left: 1px solid var(--color-border);}
#header-top ul.top-menu > li {border-right: 1px solid var(--color-border);}
#header-top ul.top-menu > li > a {display: block; min-width: 60px; text-align: center; padding: 0 5px; transition: color 0.3s;}
#header-top ul.top-menu > li > a > i {position: relative; margin-right: 3px; font-size: 9px; top: -1px;}
#header-top ul.top-menu > li > a:hover {color: #333333;}

#header-body {position: relative; height: 60px; border-bottom: 1px solid var(--color-border); transition: all 0.3s;}
#header-body h1 {position: absolute; left: 15px; top: 50%; transform: translate(0, -50%); height: 55%;}
#header-body h1 > a {display: block; height: 100%;}
#header-body h1 > a img {display: block; max-width: 100%; max-height: 100%;}
#header-body a.menu-gnb {position: absolute; right: 20px; top: 50%; transform: translate(0, -50%); width: 34px; height: 34px; font-size: 20px; color: #999999;}
#header-body a.menu-gnb i {opacity: 0; transition: all 0.3s;}
#header-body a.menu-gnb i:first-child {opacity: 1;}
#header.open #header-body a.menu-gnb > i:first-child {opacity: 0;}
#header.open #header-body a.menu-gnb > i:last-child {opacity: 1;}
#header a:where(.menu-top, .menu-gnb) i {position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}




#gnb {position: absolute; right: -100%; top: 100%; width: 100%; height: calc(100vh - 100%); background-color: #ffffff; overflow: auto; padding-bottom: 100px; transition: right 0.3s;}
#header.open #gnb {right: 0;}
#gnb > ul {padding: 30px 20px;}
#gnb > ul > li {position: relative;}
#gnb > ul > li::before {content: ''; position: absolute; left: 0; top: 0; width: 16px; height: 16px; border: 3px solid var(--color-border); border-radius: 50px; transform: translate(-40%, -40%); opacity: 0.8;}
#gnb > ul > li + li {margin-top: 30px;}
#gnb > ul > li > a {display: block; font-size: 24px; position: relative;}
#gnb > ul > li.on > a {color: var(--color-point);}
#gnb > ul > li > ul {display: grid; grid-template-columns: 1fr 1fr; margin-top: 10px; margin-left: 20px;}
#gnb > ul > li > ul > li{margin-top: 5px;}
#gnb > ul > li > ul > li > a {display: block; font-size: 16px;}
#gnb > ul > li > ul > li.on > a {color: var(--color-point);}
#gnb > ul > li[data-menu="executive"] > a {color: #ff7f00; font-weight: 500; background: url(../img/common/icon-graduate.png) 120px 0 / 30px auto no-repeat;}
#gnb > ul > li > ul > li[data-menu="award"] > a {color: #ff7f00; font-weight: 500; background: url(../img/common/icon-trophy.png) 0 0 / 20px auto no-repeat; padding-left: 20px;}


#header.mini {top: -30px; background-color: rgba(255, 255, 255, 0.8); box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);}
#header.mini #header-popup {height: 0;}
#header.mini #header-top a.menu-top {top: calc(100% + 8px);}
#header.mini #header-body {height: 50px; backdrop-filter: blur(10px);}
#header.open.mini {box-shadow: none;}
#header.popup:not(.mini) #header-popup {height: 60px;}
#header.popup:not(.mini) #header-popup div.container {display: block;}




#footer {background: #fafbfc; color: #777777; font-size: 12px; border-top: 1px solid #e4e8eb; margin-top: 60px;}
#footer > div.container {position: relative; padding: 20px 15px;}
#footer h2 {width: 100px; height: 40px; margin-bottom: 20px;}
#footer h2 img {max-height: 100%; filter: grayscale(1) opacity(0.7);}
#footer ul.link {display: flex; margin-bottom: 20px; font-size: 13px;}
#footer ul.link li + li::before {content: '|'; margin: 0 10px; font-size: 12px; color: #e4e8eb; position: relative; top: -1px;}
#footer ul.link em {color: #000000; font-weight: 700;}
#footer address span {display: block; margin: 3px 0;}
#footer address span em {color: var(--color-point); font-weight: 700; margin-right: 10px;}
#footer ul.rel-logo {display: grid; grid-template-columns: repeat(auto-fit, minmax(25%, 1fr));  margin: 30px 0 15px 0; gap: 5px;}
#footer ul.rel-logo li {display: inline-block; vertical-align: top; text-align: center;}
#footer ul.rel-logo li a {display: block; height: 30px; padding: 3px 10px;}
#footer ul.rel-logo li a img {width: 100%; height: 100%; object-fit: contain;}
#footer p.rel-org {text-align: center;}
#footer p.rel-org select {font: inherit; border: 1px solid var(--color-border); border-radius: 4px; height: 28px; padding: 0 10px; vertical-align: middle;}
#footer p.rel-org a {display: inline-block; vertical-align: middle; line-height: 26px; background-color: var(--color-point); color: #ffffff; padding: 0 15px; border-radius: 4px; margin-left: 5px;}
#footer ul.sns-link {display: flex; gap: 3px; font-size: 14px; margin-top: 20px; justify-content: center;}
#footer ul.sns-link > li {position: relative;}
#footer ul.sns-link > li.youtube > a {display: block; position: relative; width: 180px; height: 36px;}
#footer ul.sns-link > li > a img {position: absolute; left: 0; top: 50%; transform: translate(0, -50%); width: 80px;}
#footer ul.sns-link > li > a span {position: absolute; left: 90px; top: 50%; transform: translate(0, -50%); width: calc(100% - 90px); line-height: 24px; border: 2px solid #d83722; text-align: center; font-size: 14px; font-weight: 700;}
/*
#footer ul.sns-link > li > a {display: block; width: 30px; height: 30px; border: 1px solid var(--color-border); border-radius: 100px; overflow: hidden;}
#footer ul.sns-link > li > a :where(img, i) {position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); max-width: 60%; max-height: 60%;}
*/
#footer p.copyright {font-size: 11px; margin-top: 20px; color: #999999; text-align: center;}



#system-info {position: relative; padding: 10px; margin-top: 30px; border: 1px solid #999999; border-radius: 10px;}





/* main */
#main-visual {position: relative;}
#main-visual div.dino-image-slide {height: 500px;}
#main-visual div.dino-image-slide div.slogan > p {position: absolute; left: 40px; top: 100px; font-size: 20px; color: #ffffff; text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6); z-index: 100;}
#main-visual div.dino-image-slide div.slogan > p > span {display: block;}
#main-visual div.dino-image-slide div.slogan > p > span.big {font-size: 38px; font-weight: 700;}

ul.main-product-list {display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));; gap: 20px; font-size: 13px;}
ul.main-product-list > li {position: relative; border: 1px solid var(--color-border); border-radius: 10px; overflow: hidden;}
ul.main-product-list > li > a {display: block;}
ul.main-product-list > li > a > * {display: block; margin-bottom: 8px;}
ul.main-product-list > li > a > * + * {padding: 0 10px;}
ul.main-product-list > li .image {height: 240px; overflow: hidden;}
ul.main-product-list > li .image > img {width: 100%; height: 100%; object-fit: cover;}
ul.main-product-list > li em.title {white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 15px;}
ul.main-product-list > li span.desc {line-height: 20px; height: 40px; overflow: hidden; color: #999999; font-size: 13px;}
ul.main-product-list > li span.price {font-size: 18px; font-weight: 700; color: var(--color-point)}





/* sub (common) */
#sub-visual {position: relative; height: 100px; overflow: hidden;}
#sub-visual > p.bg {position: absolute; left: 0; top: 0; width: 100%; height: 100%;}
#sub-visual > p.bg img {width: 100%; height: 100%; object-fit: cover;}
#sub-visual p.slogan {position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); font-size: 30px; color: #ffffff; text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6); font-weight: 300;}

#lnb {
  --base-height: 34px;
  --size-font: 13px;
}
#lnb {position: relative; z-index: 1000; display: none;}
#lnb > div.container {position: relative; height: var(--base-height); border: 1px solid var(--color-border); font-size: var(--size-font); color: #888888;}
#lnb > div.container a {transition: all 0.3s;}
#lnb > div.container > ul {display: inline-flex; border-right: 1px solid var(--color-border);}
#lnb > div.container > ul > li {position: relative;}
#lnb > div.container > ul > li + li {border-left: 1px solid var(--color-border); padding-left: 20px; min-width: 120px;}
#lnb > div.container > ul > li + li::before {content: '\f054'; font-family: 'Font Awesome 6 Free'; font-weight: 700; position: absolute; left: 0; top: 0; width: 20px; height: 100%; border-right: 1px solid var(--color-border); text-align: center; line-height: calc(var(--base-height) - 2px); color: #bbbbbb; font-size: 8px;}
#lnb > div.container > ul > li + li > a::after {content: '\f078'; font-family: 'Font Awesome 6 Free'; font-weight: 700; position: absolute; right: 5px; top: 50%; transform: translate(0, -50%); color: #bbbbbb; font-size: 8px; transition: transform 0.3s;}
#lnb > div.container > ul > li > :where(a, em) {display: block; position: relative; line-height: calc(var(--base-height) - 2px); min-height: 100%; min-width: 70px; padding: 0 25px 0 10px;}
#lnb > div.container > ul > li > a:hover {background-color: rgba(0, 0, 0, 0.03);}
#lnb > div.container > ul > li.home > a {width: calc(var(--base-height) - 2px); min-width: initial; padding: 0;}
#lnb > div.container > ul > li.home > a i {position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
#lnb > div.container > ul > li > div {position: absolute; top: 100%; width: calc(100% - 20px); overflow: hidden; height: 0; transition: all 0.3s;}
#lnb > div.container > ul > li > div > ul {border: 1px solid var(--color-border); border-top: none; padding: 10px 0; font-size: calc(var(--size-font) - 2px); background-color: #ffffff;}
#lnb > div.container > ul > li > div > ul > li {position: relative;}
#lnb > div.container > ul > li > div > ul > li + li {margin-top: 4px;}
#lnb > div.container > ul > li > div > ul > li + li::before {content: ''; position: absolute; left: 5%; top: -2px; width: 90%; border-top: 1px dashed var(--color-border);}
#lnb > div.container > ul > li > div > ul > li > a {display: block; padding: 0 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 30px;}
#lnb > div.container > ul > li > div > ul > li > a:hover {background-color: rgba(0, 0, 0, 0.03);}
#lnb > div.container > ul > li > div > ul > li.on > a {color: var(--color-point);}

#lnb > div.container > ul > li.open > a {color: var(--color-point);}
#lnb > div.container > ul > li.open > a::after {color: var(--color-point); transform: translate(-50%, -50%) rotate(180deg);}
#lnb > div.container > ul > li.open > div {box-shadow: 2px 2px 3px 0 rgba(0, 0, 0, 0.1);}

body.sub #main {position: relative; max-width: var(--size-content-width); margin: 0 auto; padding: 40px 0 80px 0;}
body.sub #main > h2 {position: relative; font-size: 34px; font-weight: 400; text-align: center; margin-bottom: 30px;}
body.sub #main > h2::before {content: ''; position: absolute; left: 50%; top: -4px; transform: translate(-50%, 0); width: 30px; height: 2px; background-color: var(--color-point);}



/* 콘텐츠 페이지 디자인 */

/* 콘텐츠 가이드 */
section.content {font-size: 15px; padding: 0 20px;}
section.content + section.content {margin-top: 60px;}
section.content > section + section {margin-top: 40px;}
section.content h3.title {position: relative; font-size: 22px; font-weight: 400; margin-bottom: 30px;}
section.content * + h3.title {margin-top: 40px;}
section.content h3.title::before {content: ''; position: absolute; left: 0; bottom: -8px; width: 30px; height: 2px; background-color: var(--color-point); border-radius: 10px;}
section.content h4.title {position: relative; font-size: 18px; font-weight: 400; margin-bottom: 20px;}
section.content p.paragraph {margin: 20px 0;}
section.content p.image {text-align: center; margin: 20px 0;}

section.content dl.info {position: relative; margin: 20px 0;}
section.content dl.info > dt {position: relative; font-size: 18px; font-weight: 500; margin-bottom: 10px; padding-left: 20px;}
section.content dl.info > dt::before {content: ''; position: absolute; left: 0; top: 50%; transform: translate(0, -50%); width: 4px; height: 4px; border: 2px solid var(--color-point); border-radius: 10px;}
section.content dl.info > dd + dt {margin-top: 20px;}
section.content dl.info > dd {padding-left: 25px;}
section.content dl.info > dd em {font-weight: 500;}

section.content ul.info {position: relative; margin: 20px 0;}
section.content ul.info > li {position: relative; padding-left: 20px; line-height: 1.8em;}
section.content ul.info > li::before{content: '\f0da'; font-family: 'Font Awesome 6 Free'; font-weight: 700; position: absolute; left: 0; top: 0; color: var(--color-point);}
section.content ul.info > li + li {margin-top: 4px;}
section.content ul.info > li em {font-weight: 500; color: var(--color-point);}
section.content ul.info > li table {margin-top: 10px; margin-bottom: 20px;}
section.content ul.info > li a.btn {display: inline-block; vertical-align: middle; padding: 4px 14px; border: 1px solid #f9f9f9; font-size: 14px; text-align: center; border: 1px solid var(--color-point); border-radius: 4px; line-height: 1.2em; color: var(--color-point); transition: all 0.3s;}
section.content ul.info > li a.btn:hover {background-color: var(--color-point); color: #ffffff;}
section.content ul.info .desc {font-size: 0.9em; color: #666666; display: block;}

#naver-map {height: 300px; background-color: #f9f9f9; margin: 0 auto;}

table.content {width: 100%; border-top: 2px solid #666666; border-bottom: 2px solid #666666; text-align: center; font-size: 14px;}
table.content.left {text-align: left;}
table.content colgroup {display: none;}
table.content th,
table.content td {border-right: 1px solid #e0e0e0; border-bottom: 1px solid #e0e0e0; padding: 4px 10px;}
table.content th:last-child,
table.content td:last-child {border-right: none;}
table.content th {text-align: center;}
table.content thead {background-color: #f9f9f9;}
table.content tbody th {background-color: #f9f9f9;}
table.content.member tbody tr th {width: 70px;}
table.content.member-type tbody th {width: 80px;}




/* 인사말 */
section.greetings {position: relative; font-size: 16px; padding: 0 20px 200px 20px; background: url(../img/intro-greetings-president.png) right -40px bottom / 250px auto no-repeat;}
section.greetings p.paragraph + p.paragraph {margin-top: 20px;}
section.greetings p.sign {margin-top: 40px; font-size: 15px;}
section.greetings p.sign > * {display: block;}
section.greetings p.sign > .name {font-weight: 700; font-size: 18px; margin-top: 10px;}

/* 창립취지 (CI) */
section.content div.logo {text-align: center;}
section.content div.logo a {display: inline-block; padding: 4px 20px; border: 1px solid #999999; border-radius: 8px; font-size: 14px; margin-top: 10px; transition: all 0.3s;}
section.content div.logo a:hover {background-color: var(--color-point); color: #ffffff; border-color: var(--color-point);}

/* 조직구성 */
ul.org-card {position: relative; overflow: hidden; font-size: 14px; color: #666666;}
ul.org-card > li {position: relative; padding: 12px 15px 12px 110px; border: 1px solid #e0e0e0; border-radius: 8px; margin-bottom: 20px; margin-right: 2%;}
ul.org-card > li:nth-child(3n) {margin-right: 0;}
ul.org-card > li > * {display: block;}
ul.org-card > li > em.name {font-size: 24px; font-weight: 500;}
ul.org-card > li > em.name ~ span {line-height: 2em;}
ul.org-card > li > span.org ~ span {border-top: 1px dashed #e0e0e0;}
ul.org-card > li span.photo {position: absolute; left: 15px; top: 50%; transform: translate(0, -50%); width: 80px; height: 80px; border-radius: 100px; overflow: hidden;}
ul.org-card > li span.photo img {display: block; width: 100%; height: 100%; object-fit: cover;}
ul.org-card > li span.org::before {content: '\f1ad'; font-family: 'Font Awesome 6 Free'; font-weight: 700; margin-right: 10px; width: 20px;}
ul.org-card > li span.position::before {content: '\f0e8'; font-family: 'Font Awesome 6 Free'; font-weight: 700; margin-right: 10px; width: 20px;}
ul.org-card > li span.email::before {content: '\f0e0'; font-family: 'Font Awesome 6 Free'; font-weight: 700; margin-right: 10px; width: 20px;}

/* 회원사 현황 */
ul.company-member {position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 20px;}
ul.company-member > li {position: relative; padding: 10px 15px; height: 80px; border: 1px solid #e0e0e0; border-radius: 10px; background-color: #ffffff;}
ul.company-member > li img {display: block; width: 100%; height: 100%; object-fit: contain;}
@media (min-width: 600px) {
  ul.company-member {grid-template-columns: 1fr 1fr 1fr;}
  ul.company-member > li {height: 90px;}
}

/* 최고위 과정 소개 */
ul.executive-feature {position: relative;}
ul.executive-feature > li {border: 1px solid #e0e0e0; border-radius: 10px; padding: 10px;}
ul.executive-feature > li + li {margin-top: 20px;}
ul.executive-feature > li > em {display: block; background: #cee5e1 url(../img/executive-icon-01.png) 10px center / 50px auto no-repeat; color: #1b9c9a; font-size: 20px; font-weight: 700; border-radius: 10px; padding: 10px 0 10px 70px; margin-bottom: 20px;}
ul.executive-feature > li > em span {display: block; color: #333333; font-size: 15px;}
ul.executive-feature > li > ul {padding: 0 10px;}
ul.executive-feature > li > ul > li {position: relative; padding-left: 14px; font-size: 16px;}
ul.executive-feature > li > ul > li + li {margin-top: 4px;}
ul.executive-feature > li > ul > li::before {content: ''; position: absolute; left: 0; top: 8px; width: 4px; height: 4px; background-color: #999999; border-radius: 10px;}
ul.executive-feature > li:nth-child(2) > em {background-image: url(../img/executive-icon-02.png);}
ul.executive-feature > li:nth-child(3) > em {background-image: url(../img/executive-icon-03.png);}
ul.executive-feature > li:nth-child(4) > em {background-image: url(../img/executive-icon-04.png);}


/* 이미지 갤러리 상세보기 */
div.gallery ul.image > li + li {margin-top: 10px;}
div.gallery ul.image > li img {width: 100%;}






/* 메뉴 그룹별 디자인 적용 */
/*
body[class^="sub intro"] {background-color: red;}
body[class^="sub member intro"] {background-color: red;}
*/


/* [참조] */
/*
background-color: rgba(255, 255, 255, 0.5); backdrop-filter: blur(10px);
box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
*/





