@charset "utf-8";
@font-face {
    font-family:'NanumSquareNeo';
    font-weight: normal;
    src: url('NSneo/NanumSquareNeoTTF-bRg.woff') format('woff');
}
@font-face {
    font-family:'NanumSquareNeo';
    font-weight: 700;
    src: url('NSneo/NanumSquareNeoTTF-cBd.woff') format('woff');
}
@font-face {
    font-family:'NanumSquareNeo';
    font-weight: 800;
    src: url('NSneo/NanumSquareNeoTTF-dEb.woff') format('woff');
}

*:focus-visible{outline:0.3rem solid #000; box-shadow: inset 0.2rem 0.2rem #ffd84e, inset -0.2rem -0.2rem #ffd84e;}
* {box-sizing:border-box;}
body, body * {color: #333; font-family:'NanumSquareNeo', 'Malgun Gothic', '맑은고딕', sans-serif;}
html,body,div,p,dl,dt,dd,ol,ul,li,label,legend,table,input,button {font-family:'NanumSquareNeo', 'Malgun Gothic', '맑은고딕', sans-serif;}
select, textarea {font-family:'NanumSquareNeo', 'Malgun Gothic','맑은고딕',sans-serif;}

:root {
	--text: #333;
	--more: url(../img/more.svg) no-repeat 0 0;
	--more-g: url(../img/more-g.svg) no-repeat 0 0;
	--lnb: url(../img/lnb.svg) no-repeat 0 0;
	--bg01: #FFFBD0;
	--d-org: #EF6134;
	--point_p: #8C70FF;
	--point_b: #5391E8;
	--point_o: #FF855E;
	--point_y: #FFE000;
	--gray: #9E9E9E;
}

.fixed {
	overflow: hidden;
}

.wrap {
	margin: 0 auto;
	max-width: 1400px;
	width: 100%;
}

header {
	position: relative;
	background: var(--bg01);
	z-index: 999;
}

header .wrap {	
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 130px;
}

h1 a {
	display: block;
	line-height: 0;
}

#lnb>ul {
	display: flex;
	word-break: keep-all;
}

#allmenu-btn,
#lnb h2 a {
	display: block;
	width: 50px;
	height: 50px;
	border-radius: 20px;
	background: #84A6FF var(--lnb);
}

footer {
	padding-top: 70px;
	padding-bottom: 70px;
	background: #3A4C7B;
}

footer .wrap {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

footer .btm-logo {
	margin: 0;
	width: 330px;
	height: 44px;
	background: url(/open_content/isel/img/btm-logo.svg) no-repeat center / 100%;
}

footer .copy {
	text-align: center;
}

footer .copy address {
	color:#FFF;
	font-size: 15px;
	font-weight: 700;
	line-height: 160%;
}

footer .copy p {
	color: #FFF;
	font-size: 12px;
	font-weight: 700;
	line-height: 160%;
}

footer .wrap>a {
	font-size: 14px;
	font-weight: 700;
	line-height: 160%;
	padding: 8px 25px;
	border-radius: 8px;
	background: #FFF;
}

@media screen and (min-width:1025px){	
	.dp_mb {
		display: none;
	}

	#lnb {
		display: flex;
		align-items: center;
		gap: 80px;
	}

	#allmenu-btn {		
		background-size: auto 50px;
	}

	#allmenu {
		position: fixed;
		left: 0;
		top: 0;
		padding-top: 100px;
		padding-bottom: 100px;
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.40);
		overflow-y: auto;
		z-index: 999;
	}

	#allmenu .allmenu-box {
		position: relative;
		display: flex;
		flex-direction: column;
		align-items: center;
		margin: 0 auto;
		padding: 60px 180px;
		max-width: 760px;
		border-radius: 50px;
		background: #FFF;
	}
	
	#allmenu .allmenu-box>p>img {
		width: 300px;
	}
	
	#allmenu .allmenu-box>ul {
		width: 100%;
	}

	#allmenu .allmenu-box>ul>li {
		text-align: center;
		margin-top: 36px;
	}

	#allmenu .allmenu-box>ul>li>a { 
		position: relative;
		display: block;
		padding: 22px 20px;
		border-radius: 10px;
		color: #fff;
		font-size: 16px;
		font-weight: 800;
		background: var(--point_o);
	}

	#allmenu .allmenu-box>ul>li>a::before {
		content: '';
		position: absolute;
		right: 20px;
		top: calc(50% - 10px);
		width: 20px;
		height: 20px;
		background: var(--lnb);
		background-position: -80px 0;
	}

	#allmenu .sub-menu {
		display: flex;
		flex-wrap: wrap;
		gap: 10px;
		margin-top: 18px;
	}

	#allmenu .sub-menu>li {
		flex: 1 1 auto;
		width: calc(50% - 5px);
	}

	#allmenu .sub-menu>li>a {
		display: block;
		padding: 14px 5px;
		color: var(--d-org);
		border-radius: 10px;
		background: #FEEDB3;
	}
	
	#allmenu .sub-menu>li>a span {
		font-size: 15px;
		color: var(--d-org);
	}

	#allmenu .close {
		position: absolute;
		top: 0;
		right: -72px;
		width: 52px;
		height: 52px;
		border-radius: 85px;
		background: #FFF url(../img/allmenu-close.svg) no-repeat center;
	}

	#lnb h2 {
		display: none;
	}

	#lnb>ul {
		gap: 40px;
	}
	
	#lnb>ul>li {
		position: relative;
		font-size: 20px;
	}

	#lnb>ul>li>a {
		font-size: 20px;
		font-weight: 700;
		transition: .3s;
	}
	
	#lnb>ul>li:hover>a,
	#lnb>ul>li.select>a {
		color: var(--d-org);
		font-weight: 800;
	}

	#lnb>ul>li>.sub-menu {
		position: absolute;
		left: calc(50% - 70px);
		display: none;
		text-align: center;
		margin-top: 24px;
		padding: 20px 10px;
		min-width: 140px;
		border-radius: 20px;
		background: #FFF;
		box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.10);
		box-sizing: border-box;
	}

	#lnb>ul>li:nth-child(1)>.sub-menu {
		left: calc(50% - 190px / 2);
		min-width: 190px;
	}

	#lnb>ul>li>.sub-menu a {
		display: block;
		padding: 15px 10px;
		font-size: 17px;
	}

	#lnb>ul>li.sub-menu a span {
		color: #7D7D7D;
		font-weight: 700;
	}
	
	#lnb>ul>li>.sub-menu a:hover span,
	#lnb>ul>li>.sub-menu .select a span {
		color: var(--text);
		font-weight: 800;
	}
}

@media screen and (max-width:1024px){	
	.dp_mb {
		display: block;
	}

	.wrap {
		padding-left: 20px;
		padding-right: 20px;
		box-sizing: border-box;
	}

	header .wrap {
		height: 70px;
	}
	
	h1 a {
		max-width: 200px;
	}
	
	h1 a img {
		width: 100%;
	}

	#allmenu-btn {
		display: none;
	}

	#lnb h2 a {
		width: 30px;
		height: 30px;
		border-radius: 12px;
	}

	#lnb h2 a.close {
		background-position: -30px 0;
	}

	#allmenu {
		display: none;
	}

	#lnb>ul {
		position: fixed;
		left: 0;
		top: 70px;
		display: none;
		padding: 50px 40px 60px 40px;
		width: 100%;
		height: calc(100% - 70px);
		border-top: 1px solid rgba(0, 0, 0, 0.10);
		background: var(--bg01);
		overflow-y: auto;
		box-sizing: border-box;
	}

	#lnb>ul>li {
		text-align: center;
		margin-top: 18px;
	}

	#lnb>ul>li:first-child {
		margin-top: 0;
	}

	#lnb>ul>li>a { 
		position: relative;
		display: block;
		padding: 16px 20px;
		border-radius: 10px;
		font-size: 16px;
		font-weight: 700;
		background: #FFF;
		transition: .3s;
	}

	#lnb>ul>li>a::before {
		content: '';
		position: absolute;
		right: 20px;
		top: calc(50% - 10px);
		width: 20px;
		height: 20px;
		background: var(--lnb);
		background-position: -60px 0;
	}
	
	#lnb>ul>li>a:hover,	
	#lnb>ul>li.select>a {
		color: #fff;
		background: var(--point_o);
	}	
	
	#lnb>ul>li>a:hover::before,	
	#lnb>ul>li.select>a::before {
		background-position: -80px 0;
	}	

	#lnb>ul>li>.sub-menu {
		display: none;
		flex-wrap: wrap;
		gap: 10px;
		margin-top: 10px;
		transition: .3s;
	}

	#lnb>ul>li.select>.sub-menu {
		display: flex;
	}

	#lnb>ul>li>.sub-menu>li {
		flex: 1 1 auto;
		width: calc(50% - 5px);
	}

	#lnb>ul>li>.sub-menu>li>a {
		display: block;
		padding: 14px 5px;
		color: var(--d-org);
		border-radius: 10px;
		background: #FEEDB3;
	}

	#lnb>ul>li>.sub-menu>li>a span {
		color: var(--d-org);
		font-size: 15px;
	}

	footer {		
		padding-top: 36px;
		padding-bottom: 36px;
	}

	footer .wrap {
		flex-direction: column;
		gap: 20px;
	}

	footer .btm-logo {
		width: 155px;
		height: 19px;
	}

	footer .copy address {
		font-size: 12px;
	}

	footer .copy p {
		margin-top: 8px;
		font-size: 10px;
	}
	
	footer .wrap>a {
		color: rgba(255, 255, 255, 0.60);
		font-size: 12px;
		border-radius: 5px;
		background: rgba(0, 0, 0, 0.20);
	}
}