@font-face {
	font-family: "Noto Sans KR";
	font-weight: 100;
	src: url("/fonts/notosanskr-regular.woff2") format("woff2"),
			url("/fonts/notosanskr-regular.woff") format("woff")
}

@font-face {
	font-family: "Noto Sans KR";
	font-weight: 400;
	src: url("/fonts/notosanskr-medium.woff2") format("woff2"),
			url("/fonts/notosanskr-medium.woff") format("woff")
}

@font-face {
	font-family: "Noto Sans KR";
	font-weight: 700;
	src: url("/fonts/notosanskr-bold.woff2") format("woff2"),
			url("/fonts/notosanskr-bold.woff") format("woff")
}

* { margin: 0; padding: 0; position: relative; box-sizing: border-box; -webkit-tap-highlight-color: transparent; outline: none; word-break: break-all; touch-action: pan-y; background: none; word-break: keep-all; }
*::selection { background-color: #000; color: #FFF; }
*::placeholder { color: #AAA; }
html, body { width: 100%; float: left; background-color: #FFF; font-family: "Noto Sans KR", sans-serif; font-weight: 400; font-size: 13px; color: #000; overflow-x: hidden; }
img { vertical-align: middle; -webkit-perspective: 1; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; max-width: 100%; }
ul, li { list-style: none; }
a { text-decoration: none; color: inherit; }
input, select, button, textarea { appearance: none; -webkit-appearance: none; -webkit-border-radius: 0; border: 0; font-family: "Noto Sans KR", sans-serif; font-weight: 400; font-size: 13px; color: #000; }
input[type="password"] { font-family: "Noto Sans KR", dotum, sans-serif; }
input[type="file"] { display: none; }
input[type="checkbox"] { appearance: auto; -webkit-appearance: auto; cursor: pointer; vertical-align: middle; }
input[type="radio"] { appearance: auto; -webkit-appearance: auto; cursor: pointer; vertical-align: middle; }
select { appearance: auto; -webkit-appearance: auto; cursor: pointer; vertical-align: middle; }
textarea { resize: none; }
button, label { cursor: pointer; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
table { width: 100%; float: left; table-layout: fixed; border-collapse: collapse; }
i { vertical-align: middle; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
input::-webkit-outer-spin-button, input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
 
/* 공용 */
body.on #mside { display: block; }
body.on { left: -320px; overflow: hidden; }
body.on #header { left: -320px; }

.fa { font: normal normal normal 14px/1 FontAwesome !important; }

.left { float: left; }
.right { float: right; }

#wrap { width: 100%; float: left; }
#wrap.active { margin-top: 100px; }

#header { position: fixed; background-color: #FFF; z-index: 10; left: 0; top: 0; width: 100%; padding: 0 50px; height: 100px; line-height: 100px; }
#header .logo { height: 30px; display: inline-block; vertical-align: middle; }
#header .logo > img { float: left; height: 100%; }
#header .logo > img.off { display: none; }
#header .logo > img.on { display: inline-block; }
#header .nav { float: right; top: 2px; }
#header .nav > li { float: left; margin-left: 50px; }
#header .nav > li > a { font-size: 20px; font-weight: 100; display: inline-block; line-height: normal; vertical-align: middle; color: #707070; }
#header .nav > li > a.on { color: #333; }

#header.off { background-color: rgba(255, 255, 255, 0); }
#header.off .nav > li > a { color: #FFF !important; }
#header.off .logo > img.off { display: inline-block; }
#header.off .logo > img.on { display: none; }

#header.active { background-color: rgba(255, 255, 255, 1); }
#header.active .nav > li > a { color: #707070 !important; }
#header.active .nav > li > a.on { color: #333 !important; }
#header.active .logo > img.off { display: none !important; }
#header.active .logo > img.on { display: inline-block !important; }
#header.active #navBtn > div { background-color: #000 !important; }

#header #navBtn { width: 25px; height: 18px; display: none; vertical-align: middle; cursor: pointer; margin-left: 10px; top: 50%; transform: translateY(-50%); float: right; }
#header #navBtn > div { position: absolute; width: 100%; height: 2px; background-color: #000; right: 0; }
#header #navBtn > div:nth-of-type(1) { top: 0; }
#header #navBtn > div:nth-of-type(2) { top: 50%; margin-top: -1px; }
#header #navBtn > div:nth-of-type(3) { bottom: 0; }
#header.off #navBtn > div { background-color: #FFF; }

#mside { position: fixed; width: 100%; height: 100%; left: 0; top: 0; z-index: 100; display: none; }
#mside > div { width: 100%; float: left; }
#mside > .background { width: 100%; height: 100%; background-color: #000; opacity: 0.5; cursor: pointer; }
#mside > .box { position: absolute; width: 320px; height: 100%; right: 0; top: 0; background-color: #FFF; z-index: 2; overflow-y: auto; padding-top: 70px; }
#mside > .box > .closeBtn { position: absolute; right: 25px; top: 25px; width: 24px; height: 18px; cursor: pointer; z-index: 2; padding: 0 !important; }
#mside > .box > .closeBtn > div { position: absolute; width: 100%; height: 2px; background-color: #000; right: 0; top: 50%; }
#mside > .box > .closeBtn > div:nth-of-type(1) { transform: rotate(45deg) translateY(-50%); right: 1px; }
#mside > .box > .closeBtn > div:nth-of-type(2) { transform: rotate(-45deg) translateY(-50%); }
#mside > .box > div { width: 100%; float: left; padding: 20px; }
#mside > .box > .list { width: 100%; float: left; }
#mside > .box > .list > li { width: 100%; float: left; }
#mside > .box > .list > li > a { width: 100%; height: 35px; line-height: 35px; float: left; padding: 0 25px; font-size: 16px; font-weight: 100; }
#mside > .box > .list > li > a > i { position: absolute; right: 25px; top: 50%; transform: translateY(-50%); color: #AAA; }
#mside > .box > .list > li > a.on { color: #000; }

#footer { width: 100%; float: left; padding: 50px 50px 300px; border-top: 1px solid #EEE; }
#footer .left { width: 100%; }
#footer .left > p { width: 100%; float: left; font-size: 13px; font-weight: 100; color: #000; margin-bottom: 5px; letter-spacing: -0.3px; }
#footer .left > p > .line { display: inline-block; vertical-align: middle; margin: 0 8px; width: 1px; height: 10px; background-color: #AAA; top: -1px; }
#footer .left > p > .item { vertical-align: middle; }
#footer .left > p > span > b { font-weight: 400; margin-right: 5px; }
#footer .left > p.small { margin-top: 20px; font-size: 12px; color: #999; margin-bottom: 0; }
#footer .right { position: absolute; right: 50px; top: 50px; z-index: 2; }
#footer .right > a { width: 40px; height: 40px; line-height: 40px; background-color: #DDD; float: left; border-radius: 100%; text-align: center; margin-left: 10px; }
#footer .right > a > img { width: 50%; opacity: 0.7; }

#main { width: 100vw; height: 100vh; float: left; background-size: cover; background-position: center; }

#portfolioList { width: 100%; float: left; padding: 100px; }
#portfolioList > .title { width: 100%; float: left; color: #515151; font-weight: 700; font-size: 63px; margin-bottom: 50px; letter-spacing: -3px; }

.portfolioList { width: 100%; float: left; margin-bottom: -5px; }
.portfolioList > li { width: calc(calc(100% - 15px) / 4); float: left; margin-right: 5px; margin-bottom: 5px; }
.portfolioList > li:nth-of-type(4n) { margin-right: 0; }
.portfolioList > li > a { width: 100%; padding-bottom: 100%; float: left; overflow: hidden; }
.portfolioList > li > a > .bg { position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: #000; opacity: 0.4; transition: opacity 0.5s; z-index: 2; }
.portfolioList > li > a > .info { position: absolute; left: 0; bottom: 0; width: 100%; z-index: 4; padding: 30px; color: #FFF; opacity: 0; transition: all 0.5s; }
.portfolioList > li > a > .info > b { font-size: 18px; font-weight: 700; }
.portfolioList > li > a > .info > span { font-size: 13px; font-weight: 100; }
.portfolioList > li > a > .shadow { position: absolute; left: -50%; bottom: -20%; width: 200%; height: 20%; box-shadow: none; opacity: 0.7; transition: all 0.5s; z-index: 3; }
.portfolioList > li > a > img { position: absolute; left: 0; top: 0; width: 100%; min-height: 100%; transform: scale(1); transform-origin: center; transition: all 0.5s; }
.portfolioList > li > a:hover > .shadow { box-shadow: 0 -45px 65px #000; }
.portfolioList > li > a:hover > .info { opacity: 1; }
.portfolioList > li > a:hover > img { transform: scale(1.2); }
.portfolioList > li > a:hover > .bg { opacity: 0; }

#portfolioBox { width: 100%; float: left; }
#portfolioBox > .visual { width: 100%; height: 100vh; float: left; background-size: cover; background-position: center; }
#portfolioBox > .visual > .bg { position: absolute; width: 100%; height: 100%; left: 0; top: 0; opacity: 0.45; background-color: #000; z-index: 2; }
#portfolioBox > .visual > .info { position: absolute; width: 100%; left: 0; bottom: 0; z-index: 3; padding: 100px; }
#portfolioBox > .visual > .info > .title { width: 100%; float: left; font-weight: 700; color: #FFF; font-size: 68px; letter-spacing: -3px; }
#portfolioBox > .visual > .info > .memo { width: 100%; float: left; font-weight: 100; color: #FFF; font-size: 21px; letter-spacing: -0.5px; }
#portfolioBox > .txt { width: 100%; float: left; font-size: 16px; font-weight: 100; line-height: 28px; padding: 100px; padding-top: 0; }
#portfolioBox > .swiper { width: 100%; float: left; padding: 0 100px; margin-bottom: 50px; margin-top: 100px; }
#portfolioBox > .swiper li { border-radius: 20px; overflow: hidden; background-color: #F5F5F5; padding-bottom: 30%; cursor: pointer; }
#portfolioBox > .swiper li > img { min-width: 100%; height: 100%; left: 50%; transform: translateX(-50%); position: absolute; top: 0; max-width: inherit; }
#portfolioBox > .swiper .swiper-button-next { right: 20px; color: #000; }
#portfolioBox > .swiper .swiper-button-prev { left: 20px; color: #000; }
#portfolioBox > .btnBox { width: 100%; float: left; margin-bottom: 100px; text-align: center; }
#portfolioBox > .btnBox > a { display: inline-block; width: 120px; height: 50px; line-height: 48px; border: 1px solid #000; color: #000; font-size: 15px; font-weight: 400px; text-align: center; transition: all 0.5s; background-color: #FFF; }
#portfolioBox > .btnBox > a:hover { color: #FFF; background-color: #000; }

.lg-actions { top: 50%; }
#lgList { display: none; }
.fp-watermark { display: none !important; }
#fp-nav span { background: #FFF !important; }

#aboutBox { width: 100%; float: left; }
#aboutBox > .section { width: 100%; float: left; }
#aboutBox > .section .pc { display: block; }
#aboutBox > .section .mo { display: none; }
#aboutBox > .section .vid { width: 100%; height: 100vh; float: left; }
#aboutBox > .section .black { position: absolute; left: 0; top: 0; z-index: 2; width: 100%; height: 100%; background-color: #000; opacity: 0.45; }
#aboutBox > .section .bg_img { width: 100%; float: left; height: 100vh; background-size: cover; background-position: center; }
#aboutBox > .section01 .title { position: absolute; left: 200px; top: 50%; transform: translateY(-50%); font-size: 72px; color: #FFF; font-weight: 700; line-height: 180px; letter-spacing: -2px; z-index: 3; }
#aboutBox > .section02 .right { width: 60%; height: 100%; }
#aboutBox > .section02 .left { width: 40%; padding-left: 100px; top: 50%; transform: translateY(-50%); }
#aboutBox > .section02 .left .title { width: 100%; float: left; color: #333; font-weight: 700; font-size: 54px; margin-bottom: 20px; }
#aboutBox > .section02 .left p.pc { width: 100%; float: left; color: #333; font-weight: 100; font-size: 16px; line-height: 28px; }
#aboutBox > .section02 .left p.mo { width: 100%; float: left; color: #333; font-weight: 100; font-size: 12px; line-height: 18px; }
#aboutBox > .section03 .left { position: absolute; left: 0; top: 100px; margin-top: 3%; z-index: 2; width: 100%; padding-left: 100px; }
#aboutBox > .section03 .left .title { width: 100%; float: left; color: #FFF; font-weight: 700; font-size: 54px; margin-bottom: 20px; }
#aboutBox > .section03 .left p.pc { width: 100%; float: left; color: #FFF; font-weight: 100; font-size: 14px; line-height: 28px; }
#aboutBox > .section03 .left p.mo { width: 100%; float: left; color: #FFF; font-weight: 100; font-size: 12px; line-height: 18px; }
#aboutBox > .section05 .formBox { position: absolute; z-index: 2; right: 200px; top: 50%; transform: translateY(-50%); background-color: rgba(0, 0, 0, 0.45); padding: 40px; color: #FFF; width: 700px; }
#aboutBox > .section05 .formBox > .title { width: 100%; float: left; text-align: center; font-size: 32px; font-weight: bold; letter-spacing: -1px; margin-bottom: 20px; }
#aboutBox > .section05 .formBox > ul { width: 100%; float: left; }
#aboutBox > .section05 .formBox > ul > li { width: 100%; float: left; margin-bottom: 5px; }
#aboutBox > .section05 .formBox > ul > li > span { width: 100px; height: 45px; line-height: 45px; float: left; font-size: 16px; font-weight: bold; }
#aboutBox > .section05 .formBox > ul > li > .input { width: calc(100% - 100px); border: 1px solid rgba(255, 255, 255, 0.3); transition: border 0.5s; font-size: 14px; color: #FFF; background-color: rgba(0, 0, 0, 0.3); font-weight: 100; }
#aboutBox > .section05 .formBox > ul > li > .input:focus { border: 1px solid rgba(255, 255, 255, 0.7) !important; }
#aboutBox > .section05 .formBox > ul > li > .input::placeholder { opacity: 0; }
#aboutBox > .section05 .formBox > ul > li > textarea { height: 200px; padding: 15px; }
#aboutBox > .section05 .formBox > ul > li > textarea::placeholder { opacity: 1 !important; }
#aboutBox > .section05 .formBox > ul > li > input { height: 45px; padding: 0 15px; }
#aboutBox > .section05 .formBox > .btn { width: 100%; float: left; margin-top: 10px; text-align: center; } 
#aboutBox > .section05 .formBox > .btn > button { width: 150px; height: 45px; text-align: center; color: #FFF; border: 2px solid #FFF; font-size: 14px; background-color: rgba(255, 255, 255, 0); transition: all 0.5s; font-weight: bold; }
#aboutBox > .section05 .formBox > .btn > button:hover { background-color: #FFF; color: #000; }
#aboutBox .portfolioList { width: 520px; margin-top: 30px; }
#aboutBox .portfolioList > li { width: calc(calc(100% - 10px) / 3); }
#aboutBox .portfolioList > li:nth-of-type(4n) { margin-right: 5px; }
#aboutBox .portfolioList > li:nth-of-type(3n) { margin-right: 0; }
#aboutBox .portfolioList > li a .info { padding: 20px; }

#floatingBox { position: fixed; right: 20px; bottom: 20px; z-index: 50; }
#floatingBox > ul { width: 50px; float: left; }
#floatingBox > ul > li { width: 100%; float: left; margin-top: 10px; }
#floatingBox > ul > li > a { width: 100%; height: 50px; text-align: center; float: left; line-height: 50px; border-radius: 100%; box-shadow: 0 5px 10px rgba(0, 0, 0, 0.45); background-color: #FFF; }
#floatingBox > ul > li > a > i { font-size: 22px !important; vertical-align: middle; top: -1px; }
#floatingBox > ul > li > a > img { width: 80%; }

@media (max-width: 780px){
	#wrap.active { margin-top: 70px; }
	#header { height: 70px; line-height: 70px; padding: 0 20px; }
	#header .logo { height: 20px; }
	#header .nav { display: none; }
	#header #navBtn { display: block; }
	
	#footer { padding: 20px 20px 50px; }
	#footer .left > p { font-size: 12px; margin-bottom: 3px; }
	#footer .left > p > .line { margin: 0 3px; }
	#footer .left > p.small { margin-top: 15px; font-size: 11px; }
	#footer .right { position: relative; right: 0; top: 0; vertical-align: middle; margin-top: 30px; width: 100%; }
	#footer .right > a { width: 30px; height: 30px; line-height: 30px; float: none; margin-left: 0; margin: 0 3px; display: inline-block; }
	
	#portfolioList { padding: 20px; }
	#portfolioList > .title { font-size: 32px; margin-bottom: 20px; letter-spacing: -0.5px; }
	
	.portfolioList > li { width: calc(calc(100% - 5px) / 2) !important; }
	.portfolioList > li:nth-of-type(2n) { margin-right: 0; }
	.portfolioList > li > a > .info { padding: 15px; }
	.portfolioList > li > a > .info > b { font-size: 14px; }
	.portfolioList > li > a > .info > span { font-size: 11px; }
	
	#portfolioBox > .visual { height: 60vh; }
	#portfolioBox > .visual > .info { padding: 20px; }
	#portfolioBox > .visual > .info > .title { font-size: 24px; letter-spacing: -0.5px; margin-bottom: 5px; }
	#portfolioBox > .visual > .info > .memo { font-size: 13px; letter-spacing: -0.2px; }
	#portfolioBox > .txt { font-size: 13px; line-height: 18px; padding: 20px; padding-top: 0; }
	#portfolioBox > .swiper { padding: 0 20px; margin-bottom: 20px; margin-top: 20px; }
	#portfolioBox > .swiper li { border-radius: 10px; padding-bottom: 65%; }
	#portfolioBox > .btnBox { margin-bottom: 40px; margin-top: 20px; }
	#portfolioBox > .btnBox > a { width: 80px; height: 40px; line-height: 38px; font-size: 13px; }
	
	#aboutBox .portfolioList { width: 100%; margin-top: 20px; }
	#aboutBox .portfolioList > li:nth-of-type(3n) { margin-right: 5px; }
	#aboutBox .portfolioList > li:nth-of-type(2n) { margin-right: 0; }
	#aboutBox .portfolioList > li:nth-of-type(5) { display: none; }
	#aboutBox .portfolioList > li:nth-of-type(6) { display: none; }
	#aboutBox > .section .pc { display: none; }
	#aboutBox > .section .mo { display: block; }
	#aboutBox > .section01 .title { left: 20px; font-size: 28px; line-height: 48px; letter-spacing: -0.5px; }
	#aboutBox > .section02 .left { width: 100%; position: absolute; left: 0; z-index: 2; padding-left: 20px; }
	#aboutBox > .section02 .left .title { font-size: 28px; margin-bottom: 10px; color: #FFF; }
	#aboutBox > .section02 .left p { color: #FFF !important; }
	#aboutBox > .section02 .left p.pc { font-size: 13px; }
	#aboutBox > .section02 .right { position: absolute; left: 0; top: 0; height: 100vh; width: 100%; }
	#aboutBox > .section02 .fp-overflow { height: 100vh; }
	#aboutBox > .section03 .left { padding: 0 20px; }
	#aboutBox > .section03 .left .title { font-size: 28px; margin-bottom: 10px; color: #FFF; }
	#aboutBox > .section03 .left p { color: #FFF !important; }
	#aboutBox > .section05 .formBox { right: 10%; padding: 20px; width: 80%; }
	#aboutBox > .section05 .formBox > .title { font-size: 24px; }
	#aboutBox > .section05 .formBox > ul > li > span { display: none; }
	#aboutBox > .section05 .formBox > ul > li > .input { width: 100%; }
	#aboutBox > .section05 .formBox > ul > li > .input::placeholder { opacity: 1; }
}