@charset "UTF-8";

/* all */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html, body {
	height: 100%;
}

html {
	font-size: 10px;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Pretendard-Regular';
	font-size: 1.6rem;
	font-weight: 400;
	color: #000;
	word-break: keep-all;
	line-height: 1.25;
	letter-spacing: -0.025em;
}

section {
	padding: 0;
}

a {
	color: #000;
	text-decoration: none;
}

li {
	list-style: none;
}

form, img {
	margin: 0;
	padding: 0;
	border: 0;
}

img {
	border: none;
	font-size: 0;
	max-width: 100%;
}

caption {
	width: 100%;
	height: 1px;
	text-indent: -9999px;
	overflow: hidden;
}

.container {
	max-width: 100%;
	padding: 0 6rem;
}

/* sitemap */
#sitemap {
	width: 100%;
	height: calc(100% - 9.8rem);
	display: block;
	position: fixed;
	top: 9.8rem;
	left: 0;
	z-index: -1;
	background-color: #fff;
	opacity: 0;
	visibility: hidden;
}

#sitemap.active {
	opacity: 1;
	visibility: visible;
	z-index: 101;
}

.wide-layout {
	width: 136.6rem;
	max-width: 100%;
	height: 100%;
	margin: auto;
	padding: 9.5rem 6rem;
	position: relative;
	z-index: 2;
}

#sitemap .sitemap-list {
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	opacity: 0;
	position: relative;
	transition: .4s .2s;
}

#sitemap.active .sitemap-list {
	opacity: 1;
}

#sitemap .sitemap-list>ul {
	width: calc(100% + 4px);
	display: flex;
	padding-left: 0;
	margin-bottom: 0;
}

#sitemap .sitemap-list>ul>li {
	width: 100%;
	display: inline-block;
	vertical-align: top;
	margin-right: -4px;
	padding: 3.5rem;
}

#sitemap .sitemap-list a.title {
	display: block;
	text-align: center;
	padding: 1.6rem 0;
	border-bottom: 2px solid #198754;
	font-size: 3rem;
	font-weight: 500;
}

#sitemap .sitemap-list a.title:hover {
	color: #198754;
}

#sitemap .sitemap-list-depth {
	padding-left: 0;
	margin-bottom: 0;
}

#sitemap .sitemap-list-depth>li {
	margin-top: 2.4rem;
	font-size: 2rem;
}

#sitemap .sitemap-list-depth>li>a {
	display: block;
	position: relative;
	color: #333;
	text-align: center;
}

#sitemap .sitemap-list-depth>li>a:hover {
	color: #198754;
}

/* header */
.header {
	width: 100%;
	padding: 0;
	position: fixed;
	height: 9.8rem;
	background-color: rgba(0,0,0,.5);
	border-bottom: 1px solid #d9d9d9;
}

.header.site {
	background-color: #fff;
}

.header.scrolled {
	background-color: #fff;
	animation: slide-down .5s;
}

.header-layout {
	width: 100%;
	height: 100%;
	max-width: 100%;
	margin: auto;
	padding: 0 19rem 0 6.1rem;
}

/*
h1.logo>a {
	color: #fff;
}

.header.scrolled h1.logo>a {
	color: #000;
}

.header.site h1.logo>a {
	color: #000;
}

h1.logo>a>span {
	color: #198754;
}
*/

.logo-b {
	display: none;
}

.header.scrolled .logo-w, .header.site .logo-w {
	display: none;
}

.header.scrolled .logo-b, .header.site .logo-b {
	display: block;
}

.navbar a {
	padding: 0;
}

.navbar>ul {
	display: table;
	margin: auto;
	table-layout: fixed;
}

.header.site .navbar>ul {
	display: none;
}

.navbar>ul>li {
	height: 100%;
	padding: 0 4.5rem;
	display: table-cell;
	transition: all .3s;
	text-align: center;
	vertical-align: middle;
	cursor: pointer;
}

.navbar>ul>li>a {
	height: 100%;
	display: block;
	font-size: 2rem;
	font-weight: 500;
	color: #fff;
	line-height: 9.8rem;
	letter-spacing: 0;
	position: relative;
}

.header.scrolled .navbar>ul>li>a {
	color: #000;
}

.navbar>ul>li>a::before {
	height: 4px;
	bottom: 0;
	background-color: #198754;
	box-shadow: 0 0.3rem 0.6rem rgba(0,0,0,.19);
	opacity: 0;
	transition: all .3s;
}

.navbar>ul>li>a:hover::before, .navbar>ul>li:hover>a::before {
	opacity: 1;
}

.navbar>ul>li>a:focus {
	font-size: 2rem;
	padding: 0;
}

.navbar .dropdown ul {
	width: 100%;
	left: 0;
	padding: 0;
	border-bottom-left-radius: .5rem;
	border-bottom-right-radius: .5rem;
}

.navbar .dropdown ul li {
	min-width: 0;
	padding: 1.5rem 0;
	text-align: center;
}

.navbar .dropdown ul a {
	display: block;
	padding: 0;
	font-size: 1.6rem;
}

.navbar .dropdown ul a:hover, .navbar .dropdown ul li:hover>a {
	color: #198754;
}

a.allmenu {
	width: 9.8rem;
	height: 9.8rem;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #198754;
	color: #fff;
	position: absolute;
	top: 0;
	right: 0;
}

a.allmenu>i {
	font-size: 4.5rem;
}

a.allmenu>i.bi-x {
	display: none;
}

/* subvisual */
#subvisual {
	background: url('/images/main/subvisual.png') no-repeat center center / cover;
	/*background-color: rgba(32, 62, 36, .4);*/
	width: 100%;
	height: 400px;
	/*padding: 22.2rem 0;
	padding-top: 32rem;*/
	display: block;
}

.subvisual-layout, .location-layout, .contents-layout {
	width: 128rem;
	max-width: 100%;
	height: 100%;
	margin: auto;
	padding: 0 6rem;
	position: relative;
}

.subvisual-layout {
	display: flex;
	align-items: center;
	padding: 0;
}

#subvisual .subvisual-txt {
	width: 100%;
	text-align: left;
	padding-top: 9.8rem;
}

#subvisual .subvisual-txt .title {
	display: block;
	/*font-size: 4.8rem;
	font-weight: 700;
	color: #fff;*/
	font-size: 13rem;
	font-weight: 600;
	color: rgba(0, 0, 0, .5);
	line-height: 1.15;
	letter-spacing: -1px;
	/*text-transform: uppercase;*/
}

#subvisual .subvisual-txt .desc {
	font-size: 3rem;
	color: #fff;
	font-weight: 500;
	line-height: 4.5rem;
	margin-top: 2rem;
}

/* location */
#location {
	width: 100%;
	height: 6.4rem;
	position: relative;
	background-color: #fff;
	z-index: 2;	
	border-bottom: 1px solid #d9d9d9;
}

#location.fixed {
	position: fixed;
	top: 9.8rem;
	left: 0;
	animation: slide-down 0.5s;
	z-index: 100;
}

.location-layout {
	display: flex;
	align-items: center;
}

#location .home {
	position: relative;
	text-align: center;
	vertical-align: top;
	width: 8.5rem;
}

#location .home a {
	width: 100%;
	height: 6.4rem;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

#location .home a:hover {
	color: #198754;
}

#location .home::after {
	display: block;
	content: '\e93e';
	font-family: 'xeicon';
	position: absolute;
	right: -0.7rem;
	line-height: 6.4rem;
	top: 0;
	font-size: 1.4rem;
	color: #555;
}

#location .location-list {
	position: relative;
	vertical-align: middle;
	margin-bottom: 0;
	z-index: 1;
}

#location .location-list>li {
	display: block;
	float: left;
	position: relative;
}

#location .location-list a {
	display: block;
	color: #333;
	font-weight: 400;
	position: relative;
	outline: none;
}

#location .location-list .state {
	font-size: 1.8rem;
	font-weight: 500;
	min-width: 19.4rem;
	line-height: 6.4rem;
	z-index: 2;
	text-align: center;
	padding: 0 2rem;
}

#location .location-list>li>a::after {
	display: block;
	content: '\e936';
	font-family: 'xeicon';
	position: absolute;
	top: 0;
	right: -2rem;
	transform: rotate(0);
	transition: .3s;
	font-size: 1.6rem;
	line-height: 6.4rem;
	color: #555;
}

#location .location-list>li.active>a::after {
	color: #198754;
	transform: rotate(180deg);
}

#location .location-list .slidedown {
	width: 100%;
	background-color: #f9f9f9;
	position: absolute;
	top: 100%;
	left: 0;
	padding: 2.2rem 4.3rem;
	border: 1.5px solid #198754;
	box-shadow: 0 0 1rem rgba(0,0,0,0.7);
	visibility: hidden;
	opacity: 0;
	z-index: -1;
	transition: all .3s;
}

#location .location-list>li.active .slidedown {
	visibility: visible;
	opacity: 1;
	z-index: 3;
}

#location .location-list .slidedown>ul {
	padding-left: 0;
}

#location .location-list .slidedown>ul>li {
	margin-bottom: 1rem;
	text-align: center;
}

#location .location-list .slidedown>ul>li:last-child {
	margin-bottom: 0;
}

#location .location-list>li.active .slidedown>ul>li>a::after {
	display: none;
}

#location .location-list>li.active .slidedown>ul>li>a:hover {
	color: #198754;
}

/* contents */
#contents {
	padding: 10rem 0 15rem;
}

.main-contents {
	padding: 0 !important;
}

.hero .info h2 {
	margin: 0;
	padding: 0;
	font-size: 7.5rem;
	font-weight: 600;
}

.hero .info p {
	display: block;
	font-size: 2.8rem;
	font-weight: 200;
	opacity: 0.9;
	/*opacity: 0;*/
	margin: 1.8rem 0 4.3rem;
}

.hero .info p span {
	color: #198754;
	opacity: 1;
}

.hero .info h2:after {
	display: none;
}

#section01,
#section02 {
	width: 100vw;
	height: 100vh !important;
}

#section01 .wide-layout,
#section02 .wide-layout,
#section03 .wide-layout,
#section04 .wide-layout,
#section05 .wide-layout {
	padding: 0 6rem;
}

#section02 .wide-layout {
	display: flex;
	justify-content: center;
	align-items: center;
}

.section-table {
	width: 100%;
	display: table;
	table-layout: fixed;
	overflow: hidden;
}

.section-wrapper {
	width: 100%;
	height: 100%;
	display: table-cell;
	vertical-align: middle;
	/*padding-top: 9.8rem;*/
}

#section04 .section-wrapper {
	padding-top: 9.8rem;
}

#section05 .section-wrapper {
	padding-top: 4.9rem;
}

.contents-table {
	width: 100%;
	display: table;
	table-layout: fixed;
}

.contents-table>div {
	width: 50%;
	display: table-cell;
	vertical-align: middle;
	position: relative;
}

/*
#section02.section-table, #section04.section-table {
	padding: 18vh 0;
}
*/

#section02 .contents-table {
	width: 85vw;
}

#section02 .title {
	width: 43.2rem;
}

#section02 img {
	/*position: absolute;
	top: 80%;
	left: 50%;
	transform: translate(-50%, -50%);
	*/
	object-fit: cover;
}

/*#section04, #section05 {
	padding-bottom: 10rem;
}*/

#section05 {
	padding-bottom: 10rem;
}

#section05 img.no-img {
	padding: 10%;
}

/*
.contents-table .title {
	
}

.section.focus .contents-table .title {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
*/

.section-title {
	position: relative;
	margin-bottom: 4rem;
}

.section-title h2 {
	font-size: 5rem;
	font-family: 'NEXON Lv1 Gothic OTF';
	font-weight: 600;
	color: #000;
	letter-spacing: 0;
	line-height: 1.1;
	margin-bottom: 1rem;
}

.section-title .desc, .slide-title {
	font-size: 2.8rem;
	font-weight: 600;
	color: #333;
	line-height: 4.2rem;
	opacity: .9;
	margin: 1.4rem 0 1.6rem;
}

.section-title .desc-sm {
	display: block;
	font-size: 2.2rem;
	font-weight: 500;
	color: #777;
	line-height: 3rem;
	opacity: .9;
}

/* .section.focus .contents-table .main-img {
		transform: translateX(0);
		opacity: 1;
		visibility: visible;
	}
	
	.contents-table .main-img {
		opacity: 0;
		visibility: hidden;
		transform: translateX(-10rem);
		transition: .5s;
	}
*/

.main-img {
	height: auto;
	position: relative;
}

.slides-3 {
	margin-top: 4.5rem;
	overflow: hidden;
}

.slides-3 .slide-table-contents {
	width: 100%;
	display: table;
	table-layout: fixed;
}

.slides-3 .slides-main-txt, .slides-3 .slides-main-img {
	width: 50%;
	display: table-cell;
	position: relative;
}

.slides-3 .slides-main-txt-wrapper {
	display: inline-block;
	vertical-align: middle;
}

.slides-title {
	display: block;
	font-family: 'Montserrat';
	font-size: 5rem;
	color: #198754;
	letter-spacing: 0;
	margin: 1.4rem 1rem 1.6rem 0;
	opacity: 1;
}

.slides-desc {
	display: block;
	font-size: 2rem;
	font-weight: 500;
	color: #555;
	line-height: 3rem;
}

.slides-detail-view {
	width: 22rem;
	height: 5.1rem;
	display: block;
	border: 1px solid #cfcfcf;
	border-radius: 3rem;
	line-height: calc(5.1rem - 2px);
	padding: 0 3.4rem;
	margin-top: 3.4rem;
}

.slides-detail-view:hover {
	background-color: #198754;
}

.slides-detail-view span {
	display: block;
	font-size: 1.8rem;
	font-weight: 500;
	color: #555;
	padding-right: 2.5rem;
	position: relative;
}

.slides-detail-view:hover span {
	color: #fff;
}

.slides-detail-view span::after {
	display: block;
	content: '\e90b';
	font-family: 'xeicon';
	font-size: 2rem;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}

.slides-3 .swiper-page-container {
	padding-right: 15.8rem;
	margin-top: 4.8rem;
	position: relative;
}

.slides-3 .swiper-pagination {
	width: 62.3rem;
	display: table;
	table-layout: fixed;
	padding-top: 2.85rem;
	position: relative;
}

.slides-3 .slides-tab {
	display: table-cell;
	position: relative;
	padding-top: 2rem;
	font-size: 2.2rem;
	font-weight: 600;
	text-align: center;
	font-family: 'Montserrat', 'Pretendard-Regular';
	border-top: 3px solid #e9e9e9;
	cursor: pointer;
	z-index: 2;
}

.slides-3 .slides-tab::before {
	width: 0;
	height: 3px;
	display: block;
	content: '';
	background-color: #198754;
	position: absolute;
	left: 50%;
	top: -3px;
	transform: translateX(-50%);
}

.slides-3 .slides-tab-active::before {
	width: 100%;
}

.slides-3 .swiper-arrow {
	position: absolute;
	top: 0;
	left: 63rem;
}

.slides-3 .swiper-button-prev,
.slides-3 .swiper-button-next {
	width: 6rem;
	height: 6rem;
	display: inline-block;
	margin: 0 -4px 0 1.5rem;
	position: relative;
	line-height: calc(6rem - 2px);
	text-align: center;
	vertical-align: middle;
	border: 1px solid #d1d1d1;
	border-radius: 50%;
}

.slides-3 .swiper-button-next {
	margin-left: 3.2rem;
}

.slides-3 .swiper-button-prev::after,
.slides-3 .swiper-button-next::after {
	display: block;
	font-family: 'xeicon';
	font-size: 2rem;
	color: #333;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.slides-3 .swiper-button-prev::after {
	content: '\e93b';
}

.slides-3 .swiper-button-next::after {
	content: '\e93e';
}

.slides-3 .swiper-button-prev:hover,
.slides-3 .swiper-button-next:hover {
	background-color: #198754;
	border: 1px solid #198754;
}

.slides-3 .swiper-button-prev:hover::after,
.slides-3 .swiper-button-next:hover::after {
	color: #fff;
}

.projects .portfolio-flters li:hover,
.projects .portfolio-flters li.filter-active {
	color: #198754;
}

.projects .portfolio-content .portfolio-info h4 {
	background-color: #198754;
}

.projects .portfolio-content .img-fluid {
	width: 100%;
	height: 227.98px;
}

.projects .portfolio-content .portfolio-info .preview-link:hover,
.projects .portfolio-content .portfolio-info .details-link:hover {
	color: #198754;
}

.recent-blog-posts .post-item:hover .post-title,
.recent-blog-posts .post-item:hover .readmore {
	color: #198754;
}

.recent-blog-posts .post-item .meta i {
	color: #198754;
}

.recent-blog-posts .post-img {
	width: 100%;
	height: 324px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.no-img {
	width: 80%;
}

/* footer */
.footer {
	font-size: 1.6rem;
	padding: 50px 0 30px;
}

/* scroll-top */
.scroll-top {
	background: #198754;
	color: #fff;
}

.scroll-top:hover {
	background-color: #aa1313;
}

.scroll-top i {
	font-size: 2.4rem;
	color: #fff;
}

/* alert */
.swal2-container .swal2-content, .swal2-container button {
	font-size: 1.6rem !important;
}

@media(max-width: 1279px) {
	.mobile-nav-active .navbar::before {
		display: none;
		z-index: -1;
	}
	
	.navbar {
		width: auto;
		max-width: 100%;
		position: static;
		top: none;
		bottom: none;
		right: none;
		z-index: 90;
		transition: none;
	}
	
	.navbar>ul {
		padding: 0;
		z-index: 90;
		background: none;
	}
	
	.navbar .dropdown ul {
		height: 100%;
		display: block;
		position: absolute;
		top: calc(100% + 30px);
		left: 0;
		padding: 0;
		margin: 0;
		background-color: #fff;
		overflow-y: hidden;
		opacity: 0;
		visibility: hidden;
		border: none;
	}
	
	.navbar a {
		color: #000;
	}
	
	.navbar .dropdown:hover>ul {
		top: 100%;
		opacity: 1;
		visibility: visible;
	}
	
	.navbar li:nth-child(2):hover>ul {
		padding-bottom: 20rem;
	}
	
	.navbar>ul>li>a::before {
		width: 100%;
		height: 4px;
		display: block;
		content: '';
		position: absolute;
		bottom: 0;
		left: 0;
		background-color: #198754;
		box-shadow: 0 0.3rem 0.6rem rgba(0,0,0,.19);
		opacity: 0;
		transition: all .3s;
	}
	
	.navbar>ul>li>a:hover::before, .navbar>ul>li:hover>a::before {
		display: block;
		content: '';
		opacity: 1;
	}
}

@media(max-width: 1000px) {
	.navbar {
		display: none;
	}
	
	.header-layout, .subvisual-layout, .contents-layout {
		padding: 0 4rem;
	}
	
	.section-wrapper {
		padding-top: 9.8rem;
	}
	
	#section04 .section-wrapper {
		padding-top: 9.8rem;
	}
	
	#section05 .section-wrapper {
		padding-top: 9.8rem;
	}
	
	.slides-3 .swiper-arrow {
		right: 0;	
	}
}

@media(max-width: 930px) {
	.slides-3 .swiper-page-container {
		padding-right: 0;
	}
	
	.slides-3 .swiper-pagination {
		width: 100%;
	}
	
	.slides-3 .swiper-arrow {
		display: none;
	}
}

@media(max-width: 800px) {
	#section02 .contents-table {
		display: block;
		width: 100%;
	}
	
	#section02 .title {
		display: block;
		width: 100%;
	}
	
	#secion02 .main-img {
		display: block;
		width: 100%;
	}
	
	#sitemap .sitemap-list>ul {
		display: block;
	}
	
	.header-layout, .subvisual-layout, .contents-layout {
		padding: 0 2rem;
	}
	
	.container {
		padding: 0 2rem;
	}
	
	#subvisual.subvisual-svc {
		padding: 15.8rem 0 6rem !important;
	}
	
	#subvisual .subvisual-layout {
		display: block !important;
	}
	
	#subvisual .subvisual-txt {
		display: block !important;
		width: 100% !important;
	}
	
	#subvisual .subvisual-img {
		display: block !important;
		width: 100% !important;
		margin-top: 6rem;
	}
	
	.slides-3 .swiper-table-contents {
		display: block;
	}
	
	.slides-3 .slides-main-txt-wrapper {
		display: block;
	}
	
	.slides-3 .slides-main-txt,
	.slides-3 .slides-main-img {
		display: block;
		width: 100%;
	}
	
	.slides-3 .slides-main-txt {
		margin-bottom: 6rem;
	}
}

@media(max-width: 500px) {
	.hero .info h2 {
		font-size: 5rem;
	}
	
	.hero .info p {
		font-size: 2.5rem;
	}
}

@media(max-width: 360px) {
	#subvisual .subvisual-txt .title {
		font-size: 4rem;
	}
	
	#location .location-list .state {
		min-width: 11rem;
	}
	
	#location .location-list .slidedown {
		padding: 2.2rem 0;
	}
}