@charset "UTF-8";


/* design guide variables */
:root {
  --color-border: #e4e8eb;
  --color-point: rgba(0, 145, 255, 1);
  --color-focus: rgba(0, 145, 255, 0.5);
  --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: 'Pretendard Variable', sans-serif; font-weight: 400; font-size: 13px; color: var(--color-text); background: #ffffff; color: #333333;}
#wrapper {overflow: hidden; min-height: 100vh; padding-top: 60px;}
#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; display: none;}
#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 + 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 {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.cert {display: grid; grid-template-columns: repeat(auto-fit, minmax(10%, 1fr)); gap: 3px; margin: 30px 0 15px 0;}
#footer ul.cert > li {overflow: hidden; text-align: center;}
#footer ul.cert > li > span img {height: 30px;}
#footer ul.cert > li > em {display: block; font-size: 8px; margin-top: 3px;}
#footer ul.rel-logo {display: grid; grid-template-columns: repeat(auto-fit, minmax(25%, 1fr));  margin: 20px 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; border: 1px solid #e0e0e0; border-radius: 4px;}
#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: 600px;}
#main-visual div.dino-image-slide div.slogan > p {position: absolute; left: 40px; top: 120px; 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; animation: image-slide-slogan-in-1 1.5s ease-out 0s 1 normal forwards;}
#main-visual div.dino-image-slide div.slogan > p > span.big {font-size: 38px; font-weight: 700; animation: image-slide-slogan-in-2 1.5s ease-out 0s 1 normal forwards;}
#main-visual div.dino-image-slide div.slogan > p > span.big span {font-weight: 400; font-size: 26px;}
@keyframes image-slide-slogan-in-1 {
  0% {opacity: 0; transform: translate(0, -30px);}
  100% {opacity: 1; transform: translate(0, 0);}
}
@keyframes image-slide-slogan-in-2 {
  0% {opacity: 0; transform: translate(0, 30px);}
  100% {opacity: 1; transform: translate(0, 0);}
}


/* 메인화면 */
.main-section {position: relative; padding: 30px 15px; margin-top: 0;}
.main-section .main-title {text-align: center; font-size: 22px; font-weight: 400; margin-bottom: 30px;}
.main-section .main-title > * {display: block;}
.main-section .main-title span.category {font-size: 16px; font-weight: 700; color: var(--color-point); margin-bottom: 10px;}
.main-section .main-title em strong {font-size: 30px; font-weight: 700; color: var(--color-point);}
.main-section .main-title em span {font-size: 14px; color: #999999; display: none;}
.main-section .main-title p {font-size: 16px; color: #999999; margin-top: 10px; font-weight: 200;}
.main-section .main-title p em {font-weight: 500; color: #dd3322;}
.main-section h4 {font-size: 18px; text-align: center; color: var(--color-point); font-weight: 300; margin-bottom: 40px;}

.main-cert {display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 10px;}
.main-cert > li {position: relative; text-align: center;}
.main-cert > li > * {display: block;}
.main-cert > li > span img {height: 60px;}
.main-cert > li > em {font-size: 12px; margin-top: 10px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}

.main-features {text-align: center; font-size: 16px;}
.main-features > li {border: 1px solid #f0f0f0; border-radius: 10px; padding: 30px 10px 20px 10px; position: relative;}
.main-features > li + li {margin-top: 30px;}
.main-features > li::before {content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.1); border-radius: 10px;}
.main-features > li > em {position: absolute; left: 50%; top: 0; transform: translate(-50%, -50%); background-color: #ffffff; line-height: 30px; width: 100px; text-align: center; border-radius: 100px; border: 1px solid var(--color-point); color: var(--color-point); font-size: 16px;}
.main-features > li.energy {background: url(../img/main-allinone-energy.png) center center no-repeat; background-size: cover;}
.main-features > li.environment {background: url(../img/main-allinone-environment.png) center center no-repeat; background-size: cover;}
.main-features > li.hygiene {background: url(../img/main-allinone-hygiene.png) center center no-repeat; background-size: cover;}
.main-features > li div.grid {display: grid; grid-template-columns: repeat(auto-fit, minmax(10px, 1fr)); gap: 10px; position: relative;}
.main-features > li div.grid > div em {display: flex; justify-content: center; align-items: center; height: 40px; background-color: rgba(0, 145, 255, 0.8); color: #ffffff; border-radius: 100px; box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.5);}
.main-features > li div.grid > div p {display: flex; justify-content: center; align-items: center; margin-top: 10px; height: 80px; background-color: rgba(255, 255, 255, 0.6); box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1); backdrop-filter: blur(6px); border-radius: 10px; box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.5);}

.main-new {margin-bottom: 30px;}
.main-new > div {text-align: center;}
.main-new > div + div {margin-top: 30px;}
.main-new > div em.title {display: inline-block; padding: 8px 20px; border: 1px solid var(--color-point); color: var(--color-point); border-radius: 100px; font-size: 18px; margin-bottom: 20px;}

.product-category {position: relative;}
.product-category > li {height: 240px; border-radius: 10px; overflow: hidden; position: relative;}
.product-category > li + li {margin-top: 20px;}
.product-category > li::before {content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 100px; background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); z-index: 10;}
.product-category > li > a {display: block; position: relative; height: 100%;}
.product-category > li > a img {width: 100%; height: 100%; object-fit: cover;}
.product-category > li > a em {position: absolute; left: 30px; top: 30px; color: #ffffff; font-size: 24px; text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.6); font-weight: 500; z-index: 10;}
.product-category > li > a em span {display: block; font-size: 14px; font-weight: 300; opacity: 0.7; text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8)}
.product-category > li > a > span {position: absolute; left: 20px; bottom: 20px; width: 100px; height: 100px; border-radius: 100px; overflow: hidden; padding: 10px; background-color: rgba(255, 255, 255, 1); border: 1px solid #e0e0e0; opacity: 0.9;}
.product-category > li > a > span + span {left: auto; right: 20px;}
.product-category > li > a > span img {width: 100%; height: 100%; object-fit: contain;}

.main-performance {position: relative;}
.main-performance > div {position: relative; overflow: hidden;}
.main-performance > div.big {grid-row: 1 / span 2; background-color: #ffffff; border: none; margin-bottom: 20px;}
.main-performance > div:not(.big) {height: 100px;}
.main-performance > div:not(.big) + div {margin-top: 20px;}
.main-performance > div > a {display: block; height: 100%; background-color: #f9f9f9; border: 1px solid #f0f0f0; border-radius: 10px; transition: all 0.3s;}
.main-performance > div > a > em {position: absolute; left: 20px; top: 20px; font-size: 22px; transition: all 0.3s;}
.main-performance > div > a > em span {display: block; font-size: 14px; color: #999999; margin-top: 2px; transition: all 0.3s;}
.main-performance > div > a > img.icon {position: absolute; right: 10px; bottom: 10px; width: 80px; transition: all 0.3s;}

.main-one-stop {margin-bottom: 30px;}
.main-one-stop > div + div {margin-top: 20px;}

.main-service {display: grid; grid-template-columns: 1fr 1fr; gap: 10px;}
.main-service > div {position: relative; border: 1px solid #e0e0e0; border-radius: 10px; min-height: 140px; background-color: #f9f9f9; overflow: hidden;}
.main-service > div img.bg {width: 100%; height: 100%; object-fit: cover;}
.main-service > div.card-01 {background: url(../img/card-bg-01.jpg) center center no-repeat; background-size: cover;}
.main-service > div.card-02 {background: url(../img/card-bg-02.jpg) center center no-repeat; background-size: cover;}
.main-service > div.card-03 {background: url(../img/card-bg-03.jpg) center center no-repeat; background-size: cover;}
.main-service > div.card-04 {background: url(../img/card-bg-04.jpg) center center no-repeat; background-size: cover; grid-column: 1 / span 2; height: 200px;}
.main-service > div > a {display: block; height: 100%;}
.main-service > div em {position: absolute; left: 20px; top: 20px; color: #ffffff; font-size: 20px; font-weight: 300; text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.4);}
.main-service > div em::before {content: ''; position: absolute; left: 0; bottom: -6px; width: 0; height: 2px; background-color: rgba(255, 255, 255, 0.8); transition: width 0.3s ease;}
.main-service > div > a:hover em:before {width: 100%;}
.main-service > div em span {display: block; font-size: 16px;}
.main-service > div .phone {position: absolute; left: 20px; top: 96px; color: #ffffff; font-weight: 700; font-size: 28px; text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6); z-index: 10;}
.main-service > div .phone > * {display: block;}
.main-service > div i {position: absolute; right: -10px; bottom: -10px; color: #ffffff; font-size: 60px; opacity: 0.6; transition: all 0.3s ease;}
.main-service > div > a:hover i {transform: scale(1.3) translate(-10px, -10px); opacity: 0.8;}





/* 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: 20px; color: #ffffff; text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6); font-weight: 300; width: 90%; text-align: center;}
#sub-visual p.slogan em {font-size: 30px; font-weight: 500;}

#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 7 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 7 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.hidden {display: none;}
section.content + section.content {margin-top: 60px;}
section.content > section + section {margin-top: 40px;}
section.content .title-01 {position: relative; font-size: 22px; font-weight: 400; margin-bottom: 20px;}
section.content * + .title-01 {margin-top: 60px;}
section.content .title-01 span {font-size: 18px; color: #999999; margin-left: 10px;}
section.content .title-01::before {content: ''; position: absolute; left: 0; top: -10px; width: 30px; height: 3px; background-color: var(--color-point); border-radius: 10px;}
section.content .title-02 {position: relative; font-size: 18px; font-weight: 400; color: var(--color-point); font-weight: 500; margin-bottom: 20px; padding-left: 28px;}
section.content .title-02::before {content: ''; position: absolute; left: 0; top: 0.3em; width: 8px; height: 8px; border-radius: 100px; border: 3px solid var(--color-point);}
section.content .title-02 span {font-size: 15px; color: #999999; margin-left: 10px;}
section.content *:not(.title-01) + .title-02 {margin-top: 50px;}

section.content p.paragraph {margin: 20px 0;}
section.content p.paragraph em {color: var(--color-point);}
section.content p.paragraph em.block {display: block;}
section.content p.paragraph span.desc {font-size: 14px; color: #999999; margin-left: 10px; display: block;}
section.content p.image {text-align: center; margin: 20px 0; border: 1px solid #e0e0e0; text-align: center;}
section.content p.image img {max-width: 100%;}
section.content p.image span {display: block; font-size: 14px; margin-top: 10px; color: #666666;}
section.content p.image.transparent {border: none;}
section.content p.ref {font-size: 16px; color: var(--color-point);}

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 7 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;}

#kakao-map {height: 400px; background-color: #f9f9f9; margin: 0 auto;}

div.dino-scroll {overflow-x: 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 .left {text-align: left; line-height: 1.6;}
table.content em {color: #d83722;}
table.content.member tbody tr th {width: 70px;}
table.content.member-type tbody th {width: 80px;}
table.content col.th {width: 100px;}
table.content.compare {width: 700px;}
table.content em.blue {color: var(--color-point);}
table.content em.red {color: #dd3322;}


/* 인사말 */
section.greetings {position: relative; font-size: 16px; padding: 0 20px 0 20px; background: url(../img/bg-wind.jpg) right bottom / 80% auto no-repeat;}
section.greetings p.image {float: right; width: 50%; border-radius: 20px; overflow: hidden; margin-left: 20px; margin-bottom: 20px;}
section.greetings p.paragraph + p.paragraph {margin-top: 20px;}
section.greetings p.paragraph em {font-size: 20px; font-weight: 700;}
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 7 Free'; font-weight: 700; margin-right: 10px; width: 20px;}
ul.org-card > li span.position::before {content: '\f0e8'; font-family: 'Font Awesome 7 Free'; font-weight: 700; margin-right: 10px; width: 20px;}
ul.org-card > li span.email::before {content: '\f0e0'; font-family: 'Font Awesome 7 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);}

/* 차별성 */
ul.ice {display: grid; grid-template-columns: 1fr 1fr 1fr; text-align: center; gap: 6px;}
ul.ice > li {border: 1px solid #e0e0e0;}
ul.ice > li > span {display: block;}
ul.ice > li > span.image {padding: 5px;}
ul.ice > li > span.image img {height: 100px;}
ul.ice > li > span.title {font-size: 14px; border-top: 1px solid #e0e0e0; padding: 6px 0;}


/* 이미지 갤러리 상세보기 */
div.gallery ul.image > li + li {margin-top: 10px;}
div.gallery ul.image > li img {width: 100%;}


/* 생산시설 */
ul.facility {display: grid; grid-template-columns: 1fr 1fr; gap: 30px;}
ul.facility > li {border: 1px solid #e0e0e0; position: relative; border-radius: 10px; overflow: hidden;}
ul.facility > li span.image {display: block;}
ul.facility > li span.image img {width: 100%;}
ul.facility > li em {position: absolute; left: 50%; bottom: 10px; transform: translate(-50%, 0); width: 180px; text-align: center; color: #ffffff; border: 1px solid #ffffff; border-radius: 100px; background-color: rgba(0, 0, 0, 0.5); font-size: 14px; line-height: 2em; box-shadow: 3px 3px 6px 0 rgba(0, 0, 0, 0.4);}
@media (max-width: 700px) {
  ul.facility {display: block;}
  ul.facility > li + li {margin-top: 30px;}
}


/* 콘텐츠 탭 */
div.content-tab {position: relative; text-align: center; font-size: 14px; margin: 30px 0;}
div.content-tab > ul {display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 0 20px;}
div.content-tab > ul > li {position: relative;}
div.content-tab > ul > li > a {display: block; line-height: 34px; padding: 0 20px; border-radius: 100px; transition: all 0.3s; border: 1px solid #e0e0e0;}
div.content-tab > ul > li.on > a {color: #ffffff; background-color: var(--color-point);}


/* 이미지 설명 */
div.desc-box {position: relative; text-align: center; font-size: 14px; text-align: center; margin: 30px 0;}
div.desc-box.left {text-align: left;}
div.desc-box > ul {display: grid; grid-template-columns: 1fr 1fr; gap: 20px; text-align: center;}
div.desc-box.full > ul {grid-template-columns: 1fr;}
div.desc-box > ul > li {position: relative; border: 1px solid #e0e0e0;}
div.desc-box > ul > li.title {grid-column: span 2;}
div.desc-box > ul > li > * {display: block;}
div.desc-box > ul > li span.image {padding: 20px 10px; height: 180px;}
div.desc-box > ul > li.no-padding span.image {padding: 0;}
div.desc-box > ul > li span.image img {width: 100%; height: 100%; object-fit: contain;}
div.desc-box > ul > li em {line-height: 40px; border-top: 1px solid #e0e0e0;}
div.desc-box > ul > li em.long {line-height: 24px; border-top: 1px solid #e0e0e0; padding: 10px;}
div.desc-box > ul > li.title em {background-color: #f0f0f0; font-weight: 700;}
div.desc-box.two > ul {grid-template-columns: 1fr;}
div.desc-box.two > ul > li span.image {padding: 20px 10px; height: 300px;}
div.desc-box.two.business > ul > li span.image {height: 250px;}
div.desc-box.three > ul {grid-template-columns: 1fr;}
div.desc-box.three > ul > li span.image {padding: 20px 10px; height: 500px;}
div.desc-box.top-title > ul > li em {border-bottom: 1px solid #e0e0e0; border-top: none;}
div.desc-box ul.model {font-size: 13px; color: #999999; border-top: 1px solid #e0e0e0; padding: 10px;}
div.desc-box ul.model > li {display: inline-block; vertical-align: middle; border: 1px solid #e0e0e0; padding: 0 16px; line-height: 24px; border-radius: 100px;}
div.desc-box.filter > ul {grid-template-columns: 1fr 1fr;}
div.desc-box.filter > ul > li em {line-height: 1.4em; padding: 10px 0; font-size: 14px;}
div.desc-box.col-2 > ul {display: grid; grid-template-columns: 1fr 1fr; gap: 30px;}
div.desc-box.col-2 > ul > li {width: auto;}
div.desc-box.col-2 > ul > li span.image {height: auto;}

div.desc-box.tall {display: grid; grid-template-columns: 1fr; text-align: center; max-width: 1000px; margin: 0 auto;}
div.desc-box.tall > ul {gap: 0; align-items: center; grid-template-columns: 1fr 1fr 1fr;}
div.desc-box.tall > ul > li span.image {padding: 0; height: auto;}

div.desc-box.procedure > ol {display: grid; grid-template-columns: 1fr 1fr; gap: 10px;}
div.desc-box.procedure > ol > li {text-align: center;}
div.desc-box.procedure > ol > li em {display: block; font-size: 16px; line-height: 30px; color: var(--color-point);}


/* 부품 제원 설명 */
div.part-desc {position: relative; border: 1px solid #e0e0e0; border-radius: 10px; padding: 10px;}
div.part-desc + div.part-desc {margin-top: 30px;}
div.part-desc p.title {color: var(--color-point); font-size: 18px; margin-bottom: 10px;}
div.part-desc ul.feature > li {position: relative; padding-left: 16px;}
div.part-desc ul.feature > li::before {content: ''; position: absolute; left: 0; top: 0.5em; width: 4px; height: 4px; border-radius: 10px; background-color: var(--color-point);}
div.part-desc ul.feature > li > em {display: inline-block; position: relative; color: var(--color-point);}
div.part-desc ul.feature > li > em::after {content: ':'; margin: 0 10px;}
div.part-desc ul.photo {display: flex; gap: 10px; margin-top: 10px;}
div.part-desc ul.photo > li {width: 80px;}
div.part-desc ul.photo.big > li {width: 100px;}

/* 부품 제원 설명 */
div.desc-image-box {position: relative; border: 1px solid #e0e0e0;}
div.desc-image-box + div.desc-image-box {margin-top: 20px;}
div.desc-image-box > div {position: relative;}
div.desc-image-box > div.desc {padding: 10px 20px; font-size: 15px;}
div.desc-image-box > div.desc h5 {font-size: 24px; margin-bottom: 24px; font-weight: 500; position: relative;}
div.desc-image-box > div.desc h5::after {content: ''; position: absolute; left: 0; bottom: -3px; width: 100%; height: 1px; background-color: var(--color-point);}
div.desc-image-box > div.desc ul > li {position: relative; padding-left: 16px; line-height: 2;}
div.desc-image-box > div.desc ul > li::before {content: ''; position: absolute; left: 0; top: 0.7em; width: 4px; height: 4px; border-radius: 10px; background-color: #999999;}
div.desc-image-box > div.desc ul > li em {font-weight: 700;}
div.desc-image-box > div.desc ul > li p.ref {font-size: 14px; color: var(--color-point);}

/* 이미지 그리드 */
div.dino-image-grid {display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px;}
div.dino-image-grid > div img {width: 100%; display: block;}
div.dino-image-grid.col-4 {grid-template-columns: 1fr 1fr;}












/* 메뉴 그룹별 디자인 적용 */
/*
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);
*/





