@charset "utf-8";

/* reset */
*,
:before,
:after {
	box-sizing: border-box;
}
html {
	overflow-y: scroll;
}
body,
p,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
form,
fieldset,
legend,
input,
textarea,
button,
select {
	margin: 0;
	padding: 0;
}
body,
input,
textarea,
select,
button,
table {
	color: #2f2f2f;
	font-family: "S-CoreDream", "맑은 고딕", "Malgun Gothic", "Apple SD Gothic Neo", sans-serif;
	font-size: 14px;
	line-height: 1.42857;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
	display: block;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: inherit;
	line-height: inherit;
}
img,
fieldset {
	border: 0;
}
img {
	max-width: 100%;
	vertical-align: top;
}
ul,
ol {
	list-style: none;
}
i,
em,
address {
	font-style: normal;
}
a {
	color: inherit;
	background-color: transparent;
	-webkit-text-decoration-skip: objects;
	text-decoration: none;
}
a:hover,
a:active,
a:focus {
	text-decoration: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
legend {
	*width: 0;
}
iframe {
	overflow: hidden;
	margin: 0;
	padding: 0;
	border: 0;
}
input::-webkit-input-placeholder {
	line-height: normal !important;
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="submit"],
input[type="tel"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="checkbox"] {
	box-shadow: none;
}
button,
input {
	border-radius: 0;
}
button {
	padding: 0;
	border: 0;
	background-color: transparent;
	cursor: pointer;
}
[onclick],
label,
select {
	cursor: pointer;
}
select {
	background: #fff;
}
select::-ms-expand {
	background: transparent;
	border: 0;
}
textarea {
	overflow: auto;
}
[hidden] {
	display: none;
}
caption {
	overflow: hidden;
	width: 1px;
	height: 1px;
	margin-top: -1px;
}
.blind,
legend {
	display: block;
	overflow: hidden;
	position: absolute;
	left: 0;
	top: -9999em;
}

.txt_hide {overflow:hidden; width:0; height:0; position:absolute; left:-9999px;}

/* common */
.skip a {
	display: block;
	position: absolute;
	left: 0;
	top: -9999em;
	z-index: 9999;
	overflow: hidden;
	width: 100%;
	background-color: #333;
	color: #fff;
	font-size: 1.2em;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	line-height: 2.2;
}
.skip a:hover,
.skip a:active,
.skip a:focus {
	top: 0;
}
.clearfix {
	*zoom: 1;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.ellipsis {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.container {
	position: relative;
	width: 1300px;
	margin: 0 auto;
}

/* thumbnail(https://codepen.io/ksm6983/pen/wvJPEvO) */
.thumb-wrap {
	overflow: hidden;
}
.center-crop-thumbnail,
.center-thumbnail {
	height: 100%;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	transition: transform 0.3s ease;
}
.center-crop-thumbnail {
	background-size: cover;
}
.center-thumbnail {
	background-size: contain;
}
span.center-crop-thumbnail,
span.center-thumbnail {
	display: inline-block;
	width: 100%;
	vertical-align: top;
}
.thumb-wrap a:hover .center-crop-thumbnail,
.thumb-wrap a:hover .center-thumbnail {
	transform: scale(1.05);
}

@media (max-width: 1400px) {
	.container {
		width: auto;
		margin: 0;
		padding: 0 50px;
	}
}
@media (max-width: 768px) {
	.container {
		padding: 0 20px;
	}

	.only-pc {
		display: none;
	}
}

/*-------------------------------------------
	header
--------------------------------------------*/
#header {
	height: 97px;
}
#header .container::after,
.gnb::after {
	content: "";
	display: block;
	clear: both;
}
.logo {
	position: sticky;
	top: 0;
	left: 0;
	z-index: 11;
	width: 308px;
}

.logo a {
	height: 259px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #002870;
	padding-left: 10px;
	border-radius: 0 0 30px 30px;
}

.logo .mobile,
.site-title {
	display: none;
}
.gnb {
	background: rgb(25, 115, 235);
	background: -moz-linear-gradient(left, rgba(25, 115, 235, 1) 0%, rgba(33, 93, 215, 1) 39%, rgba(36, 82, 206, 1) 59%, rgba(36, 82, 206, 1) 100%);
	background: -webkit-linear-gradient(left, rgba(25, 115, 235, 1) 0%, rgba(33, 93, 215, 1) 39%, rgba(36, 82, 206, 1) 59%, rgba(36, 82, 206, 1) 100%);
	background: linear-gradient(to right, rgba(25, 115, 235, 1) 0%, rgba(33, 93, 215, 1) 39%, rgba(36, 82, 206, 1) 59%, rgba(36, 82, 206, 1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1973eb', endColorstr='#2a42c1',GradientType=1 );
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	z-index: 10;
	color: #fff;
}
.gnb::before {
	content: "";
	position: absolute;
	top: 0;
	left: 100%;
	width: 2000px;
	height: 100%;
	background: #0069cf;
	box-shadow: 4px 4px 0 rgba(128, 157, 186, 0.2);
}

.gnb-list {
	font-family: "GyeonggiTitle", sans-serif;
	display: flex;
	margin: 0 -1px -0.5px 0;
	padding-left: 38.94%;
}

.gnb-list::before {
	content: "";
	height: 0;
	background-color: #fff;
	position: absolute;
	top: 97px;
	left: 0;
	right: 0;
	z-index: -1;
	opacity: 0.92;
	transition: height 0.4s ease;
}

.gnb-list > li {
	position: relative;
	text-align: center;
}

.gnb-list a {
	display: block;
}
.gnb-list .link-depth-1 {
	font-size: 22px;
	font-weight: 500;
	height: 100%;
	line-height: 97px;
	padding: 0 34px;
}
.gnb-list .link-depth-1:hover {
	color: #fff338;
}
.gnb-list .link-depth-2 {
	display: inline-block;
	font-size: 15px;
	font-weight: 500;
	word-break: keep-all;
	letter-spacing: -0.03em;
	padding: 3px 15px;
	border-radius: 15px;
}
.gnb-list .link-depth-2:hover {
	color: #fff;
	background-color: #2b74e2;
}

.gnb-list .depth-2-wrap {
	position: absolute;
	top: 97px;
	left: -10px;
	right: -10px;
	margin: 0 auto;
	z-index: 5;
	color: #3a3b3c;
	max-height: 0;
	overflow: hidden;
}

.gnb-list .depth-2 {
	padding: 20px 0;
}

.gnb-list .depth-2 > li + li {
	margin-top: 2px;
}

.gnb-list.on::before {
	display: block;
	height: 201px;
	border-bottom: 1px solid #c5d4ec;
}

.gnb-list.on .depth-2-wrap {
	max-height: 400px;
	transition: max-height 0.8s ease;
}

.gnb-option {
	width: 103px;
	height: 36px;
	line-height: 36px;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 15.86%;
	margin: auto 0;
	background: #102792;
	border-radius: 18px;
}
.gnb-option .btn-lang {
	padding: 0 24px 0 15px;
	font-size: 15px;
	font-weight: 600;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.gnb-option .btn-lang i {
	font-size: 20px;
}
.gnb-option .btn-all-menu {
	display: none;
}

/* 메인 header */
#header.main .logo {
	display: none;
}
#header.main .gnb::before {
	display: none;
}

@media (max-width: 2000px) {
	.gnb-list {
		padding-left: 34.94%;
	}
}

@media (max-width: 1800px) {
	.gnb-list {
		padding-left: 34%;
	}
	.gnb-option {
		right: 12.28%;
	}
}

@media (max-width: 1700px) {
	.gnb-list {
		padding-left: 30%;
	}

	.gnb-option {
		right: 5.03%;
	}
}

@media (max-width: 1420px) {
	.gnb-list {
		padding-left: 30%;
	}
	.gnb-option {
		right: 4%;
	}
}

@media (max-width: 1400px) {
	.gnb-list .link-depth-1 {
		padding: 0 24px;
	}
	.logo {
		left: 50px;
	}
}

@media (max-width: 1260px) {
	#header {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 5;
		height: 106px;
		background: #fff;
		border-bottom: 2px solid #052c73;
	}
	#header .container {
		padding: 0;
		position: static;
	}

	.logo {
		float: left;
		position: initial;
		margin-top: 0;
		height: 106px;
		width: 130px;
		padding-left: 20px;
		background: #002870;
		display: flex;
		align-items: center;
		justify-content: center;
	}

	.logo a {
		background: none;
		height: auto;
	}

	.logo .pc {
		display: none;
	}
	.logo .mobile {
		display: none;
		width: 74px;
		display: inline;
	}
	.site-title {
		float: left;
		display: block;
		margin: 24px 0 0 29px;
	}
	.site-title img {
		width: 162px;
	}

	.gnb {
		position: absolute;
		top: 0;
		right: 50px;
		margin-right: 0;
		box-shadow: none;
		float: none;
	}
	.gnb::before,
	.gnb-list {
		display: none;
	}
	.gnb-option {
		background: none;
		display: flex;
		align-items: center;
		width: auto;
		height: 106px;
		line-height: 106px;
		right: 0;
		margin: 0;
	}
	.gnb-option .btn-lang {
		display: inline-block;
		width: 85px;
		color: #002870;
		font-size: 18px;
		font-weight: bold;
		height: 40px;
		line-height: 40px;
		padding: 0;
		margin-right: 10px;
	}
	.gnb-option .btn-lang i {
		font-weight: bold;
		margin-right: 4px;
	}
	.gnb-option .btn-all-menu {
		display: inline-block;
		width: 54px;
		height: 40px;
		background: url("../images/common/btn_menu.png") no-repeat 50% 50% / 100% auto;
	}

	/* 메인 header */
	#header.main {
		box-shadow: 0 4px 5px rgba(0, 0, 0, 0.1);
		border-bottom: 0;
	}
	#header.main .logo {
		display: flex;
	}
}
@media (max-width: 768px) {
	#header {
		height: 65px;
		border-bottom-width: 1px;
	}
	.logo {
		width: 74px;
		height: 65px;
		padding-left: 0;
	}
	.logo .mobile {
		width: 45px;
	}
	.site-title {
		margin: 15px 0 0 20px;
	}
	.site-title img {
		width: 92px;
	}

	.gnb {
		right: 20px;
	}
	.gnb-option {
		height: 65px;
		bottom: auto;
	}
	.gnb-option .btn-lang {
		width: 52px;
		font-size: 12px;
	}
	.gnb-option .btn-lang i {
		font-size: 120%;
		margin-right: 4px;
	}
	.gnb-option .btn-all-menu {
		width: 32px;
		height: 23px;
	}
}

/*-------------------------------------------
	footer
--------------------------------------------*/
#footer {
	background: #1b3453;
	padding: 48px 0;
	position: relative;
}
#footer .container::after {
	content: "";
	display: block;
	clear: both;
}

.footer-top,
.footer-section {
	float: left;
}
.footer-top {
	margin-right: 60px;
}

.footer-logo {
	padding-top: 20px;
}

.footer-contact {
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -55px;
	color: rgba(255, 255, 255, 0.51);
	display: flex;
	align-items: center;
}
.footer-contact .tit {
	font-size: 14px;
	letter-spacing: 0.05em;
	line-height: 2;
	margin-right: 12px;
	word-spacing: -0.1em;
}
.footer-contact .num {
	font-size: 22px;
	font-weight: 600;
	line-height: 1.25;
}
.footer-contact .num a {
	display: block;
}

.footer-menu {
	color: #c4d1dc;
	font-size: 16px;
	margin-bottom: 25px;
}
.footer-menu ul {
	display: flex;
	align-items: center;
}
.footer-menu li {
	position: relative;
}
.footer-menu li + li {
	margin-left: 14px;
	padding-left: 15px;
}
.footer-menu li + li::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 2px;
	height: 14px;
	margin-top: -7px;
	background: #7d95ab;
}
.footer-menu strong {
	color: #cec98f;
	font-weight: 500;
}

.footer-family {
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: 15px;
}
.web_ci {position: absolute; top:15%; right:30%;}
.footer-family .sel-family,
.footer-family .btn-family {
	height: 34px;
	padding: 0 10px;
	background: #495d75;
	color: rgba(255, 255, 255, 1);
	vertical-align: top;
	border: 1px solid #1b3453;
	font-weight: 500;
}
.footer-family .sel-family {
	width: 210px;
	font-size: 17px;
	letter-spacing: 0.02em;
}
.footer-family .sel-family::-ms-expand {
	color: rgba(255, 255, 255, 0.45);
}
.footer-family .btn-family {
	font-size: 16px;
}

.footer-address {
	color: rgba(255, 255, 255, 0.49);
	font-size: 14px;
	line-height: 1.5;
}
.footer-address dt,
.footer-address dd {
	display: inline-block;
}
.footer-address dt {
	font-weight: 600;
	margin-right: 6px;
}

.footer-copyright {
	margin-top: 15px;
}
.footer-copyright p {
	color: rgba(255, 255, 255, 0.61);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.04em;
}

@media (max-width: 1400px) {
	.footer-contact,
	.footer-family {
		right: 50px;
	}
}
@media (max-width: 1260px) {
	#footer {
		background: #013b6d;
		padding: 64px 0 0;
	}
	#footer .container {
		padding-top: 38px;
		padding-bottom: 38px;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.footer-top {
		margin-right: 40px;
	}
	.footer-section {
		padding-right: 260px;
		width: calc(100% - 210px);
	}

	.footer-logo {
		padding-top: 0;
	}

	.footer-menu {
		position: absolute;
		bottom: 100%;
		left: 0;
		right: 0;
		height: 64px;
		background: #0a477c;
		margin-bottom: 0;
	}
	.footer-menu ul {
		display: flex;
		height: 100%;
		text-align: center;
	}
	.footer-menu li {
		flex: 1 1 auto;
		height: 100%;
	}
	.footer-menu li + li {
		margin-left: 0;
		padding-left: 0;
	}
	.footer-menu li + li::after {
		background: #365e8a;
		height: 18px;
		margin-top: -9px;
	}
	.footer-menu a {
		display: block;
		height: 100%;
		line-height: 64px;
	}

	.footer-family .sel-family,
	.footer-family .btn-family {
		background: #34628a;
	}
}
@media (max-width: 900px) {


	#footer .container {
		display: block;
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.footer-top,
	.footer-section {
		float: none;
	}
	.footer-top {
		margin-right: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.footer-section {
		width: 420px;
		max-width: 100%;
		padding-right: 0;
		margin: 25px auto 0;
	}

	.footer-logo {
		margin-right: 40px;
	}
	.footer-logo img {
		width: 120px;
	}

	.footer-contact {
		position: static;
		margin-top: 0;
	}
	.web_ci {position: static; margin:10px auto; text-align:center;}

	.footer-family {
		position: static;
		margin-top: 0;
		margin-bottom: 20px;
		display: flex;
	}
	.footer-family .sel-family {
		flex: 1 1 auto;
		min-width: 0;
	}
	.footer-family .btn-family {
		flex: 0 0 auto;
		margin-left: 4px;
	}
}
@media (max-width: 768px) {
	#footer {
		padding-top: 45px;
	}
	#footer .container {
		padding-top: 20px;
		padding-bottom: 20px;
	}
	.footer-section {
		width: 360px;
		margin-top: 20px;
	}

	.footer-logo {
		margin-right: 30px;
	}
	.footer-logo img {
		width: 78px;
	}

	.footer-contact .tit {
		font-size: 11px;
		line-height: 1.85;
	}
	.footer-contact .num {
		font-size: 15px;
	}
	.footer-contact .num a + a {
		margin-top: 3px;
	}

	.footer-menu {
		height: 45px;
	}
	.footer-menu li + li::after {
		width: 1px;
		height: 14px;
		margin-top: -7px;
	}
	.footer-menu a {
		line-height: 45px;
		font-size: 13px;
	}

	.footer-family {
		margin-bottom: 15px;
	}
	.footer-family .sel-family,
	.footer-family .btn-family {
		height: 33px;
		font-size: 14px;
	}

	.footer-address,
	.footer-copyright p {
		font-size: 11px;
	}
	.footer-copyright {
		margin-top: 10px;
	}
}

/* 전체메뉴 */
.open-all-menu {
	overflow: hidden;
	height: 100%;
}

#all_menu {
	display: none;
	text-align: left;
}
#all_menu .all-menu-wrap {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 5510;
	width: 460px;
	height: 100%;
	background: #fff;
	transition: all 0.3s ease;
	transform: translateX(100%);
	overflow-y: auto;
}
#all_menu .all-menu-title {
	position: relative;
	height: 180px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-bottom: 3px solid #256fcb;
}
#all_menu .all-menu-title img:first-of-type {
	width: 101px;
	margin-right: 20px;
}
#all_menu .all-menu-title img:last-of-type {
	width: 163px;
}
#all_menu .all-menu-body {
	display: flex;
	height: calc(100vh - 180px);
	flex-direction: column;
	justify-content: space-between;
}
#all_menu .m-menu-list {
	letter-spacing: -0.04em;
}
#all_menu .m-menu-list > li {
	border-bottom: 1px dashed #cbcbcb;
	background-color: #fff;
	padding: 0 40px;
}
#all_menu .m-menu-list a {
	display: block;
}
#all_menu .m-menu-list .link-depth-1:hover,
#all_menu .m-menu-list .link-depth-2:hover {
	color: #256fcb;
	font-weight: 600;
}
#all_menu .m-menu-list .link-depth-1 {
	position: relative;
	display: block;
	width: 100%;
	color: #5b5b5c;
	font-size: 28px;
	padding: 18px 15px;
	font-weight: 500;
	text-align: left;
}
#all_menu .m-menu-list .link-depth-1:before {
	content: "";
	position: absolute;
	top: 35px;
	left: 0;
	width: 4px;
	height: 4px;
	background: #464444;
}
#all_menu .m-menu-list .link-depth-1:hover:before {
	background: currentColor;
}
#all_menu .m-menu-list .link-depth-1:after {
	content: "\f078";
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -7px;
	font-family: "Font Awesome 5 Pro";
	color: #5b5b5c;
	font-size: 19px;
	font-weight: bold;
	line-height: 1;
}
#all_menu .m-menu-list .depth-2 {
	display: none;
	padding: 0 20px 18px;
}
#all_menu .m-menu-list .depth-2 > li {
	position: relative;
}
#all_menu .m-menu-list .depth-2 > li + li {
	margin-top: 9px;
}
#all_menu .m-menu-list .link-depth-2 {
	position: relative;
	color: #606060;
	font-size: 17px;
	font-weight: 500;
	padding-left: 15px;
}
#all_menu .m-menu-list .link-depth-2::before {
	content: "-";
	position: absolute;
	top: 0;
	left: 0;
	color: #606060;
}
#all_menu .m-menu-list .link-depth-2:hover:before {
	color: #256fcb;
}
#all_menu .m-menu-list > li.on .link-depth-1:after {
	content: "\f077";
	color: #467bdb;
	font-weight: 600;
}
#all_menu .m-menu-list > li.on .depth-2 {
	display: block;
}
#all_menu .m-menu-option {
	display: flex;
	background: #3a5e9f;
	height: 64px;
	justify-content: center;
	align-items: center;
}
#all_menu .m-menu-option li + li {
	position: relative;
	padding-left: 25px;
	margin-left: 25px;
}
#all_menu .m-menu-option li + li::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 1px;
	height: 16px;
	margin-top: -8px;
	background: #90a0c3;
}
#all_menu .m-menu-option a {
	color: #fff;
	font-size: 17px;
	font-weight: 500;
}
#all_menu .m-menu-option a strong {
	color: #ead41a;
	font-weight: 500;
}
#all_menu .btn-wrap {
	position: absolute;
	top: 0;
	right: 0;
	width: 55px;
	height: 55px;
	background: #38465e;
}
#all_menu .btn-wrap .btn-close {
	width: 100%;
	height: 100%;
	color: #fff;
	font-size: 36px;
}
#all_menu .all-menu-bg {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 5500;
	background: rgba(0, 0, 0, 0.65);
}
#all_menu.on {
	z-index: 1001;
}
#all_menu.on .all-menu-wrap {
	transform: translateX(0);
	-ms-transform: translateX(0);
}
#all_menu.on .all-menu-bg {
	display: block;
}

@media (max-width: 1260px) {
	#all_menu {
		display: block;
	}
}
@media (max-width: 768px) {
	#all_menu .all-menu-wrap {
		width: 80%;
		max-width: 360px;
	}
	#all_menu .all-menu-title {
		height: 108px;
		border-bottom-width: 2px;
	}
	#all_menu .all-menu-title img:first-of-type {
		width: 59px;
		margin-right: 15px;
	}
	#all_menu .all-menu-title img:last-of-type {
		width: 94px;
	}
	#all_menu .all-menu-body {
		height: calc(100% - 108px);
	}
	#all_menu .m-menu-list > li {
		padding: 0 26px;
	}
	#all_menu .m-menu-list .link-depth-1 {
		font-size: 18px;
		padding: 12px;
	}
	#all_menu .m-menu-list .link-depth-1:before {
		top: 24px;
		left: 0;
		width: 2.5px;
		height: 2.5px;
	}
	#all_menu .m-menu-list .link-depth-1:after {
		font-size: 14px;
	}
	#all_menu .m-menu-list .link-depth-2 {
		font-size: 13px;
	}
	#all_menu .m-menu-list .depth-2 {
		padding: 0 12px 15px;
	}
	#all_menu .m-menu-list .depth-2 > li + li {
		margin-top: 5px;
	}
	#all_menu .btn-wrap {
		width: 40px;
		height: 40px;
	}
	#all_menu .btn-wrap .btn-close {
		font-size: 24px;
	}
	#all_menu .m-menu-option {
		height: 39px;
	}
	#all_menu .m-menu-option li {
		flex: 1 1 auto;
		text-align: center;
	}
	#all_menu .m-menu-option li + li {
		padding-left: 0;
		margin-left: 0;
	}
	#all_menu .m-menu-option li + li::before {
		height: 8px;
		margin-top: -4px;
	}
	#all_menu .m-menu-option a {
		font-size: 11px;
	}
}
/*=========================================================================================================================================*/
/**
 *	서브 공통
 */

/* 타이틀 */
.contents-title {
	word-break: keep-all;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
h3.contents-title {
	position: relative;
	color: #2d2d2d;
	font-size: 26px;
	font-weight: 600;
	margin-bottom: 15px;
	letter-spacing: -0.04em;
}
h4.contents-title {
	position: relative;
	margin-bottom: 10px;
	color: #2d2d2d;
	font-size: 20px;
	font-weight: 600;
	padding-left: 24px;
}
h4.contents-title::after {
	content: "\f192";
	position: absolute;
	top: 8px;
	left: 0;
	color: #2d2d2d;
	font-size: 14px;
	font-weight: bold;
	font-family: "Font Awesome 5 Pro";
	line-height: 1;
}

@media (max-width: 768px) {
	h3.contents-title {
		font-size: 20px;
		margin-bottom: 12px;
	}
	h4.contents-title {
		font-size: 16px;
		padding-left: 18px;
		margin-bottom: 5px;
	}
	h4.contents-title::after {
		font-size: 11px;
		top: 4px;
	}
}

/* 텍스트 */
.contents-desc {
	color: #2d2d2d;
	font-size: 16px;
	word-break: keep-all;
	overflow-wrap: break-word;
	word-wrap: break-word;
	letter-spacing: -0.04em;
	line-height: 1.75;
}
.contents-desc.blue {
	color: #0146ac;
	margin-top: 10px;
}
.contents-desc strong {
	color: #3180da;
	font-weight: 400;
}
h4.contents-title ~ .contents-desc {
	padding-left: 24px;
}

.text-desc {
	display: inline-block;
	color: #222;
	word-break: keep-all;
	overflow-wrap: break-word;
	vertical-align: middle;
	letter-spacing: -0.04em;
}
.text-blue {
	color: #107ff6;
	text-decoration: underline;
}
.text-green {
	color: #2ebb88;
	text-decoration: underline;
}
.text-mint {
	color: #00c5b5;
	text-decoration: underline;
}
.text-warning {
	color: #e2304d;
	font-weight: 500;
}
.control-info {
	color: #ee5e57;
	word-break: keep-all;
}
.required {
	position: relative;
	word-break: keep-all;
}
.required::after {
	content: "*";
	margin-left: 4px;
	color: #ee5e57;
	font-weight: bold;
	vertical-align: top;
	line-height: 1;
}

.text-with-icon {
	margin-right: 6%;
	position: relative;
	position: relative;
	padding-left: 1.5em;
}
.text-with-icon i {
	margin-right: 5px;
	color: #2668b5;
	font-size: 111%;
	position: absolute;
	top: 0.15em;
	left: 0;
}

@media (max-width: 768px) {
	.contents-desc {
		font-size: 13px;
	}
	h4.contents-title ~ .contents-desc {
		padding-left: 18px;
	}
}

/* 링크 */
.text-link {
	font-size: inherit;
	word-break: keep-all;
	overflow-wrap: break-word;
}
.text-link:hover {
	color: #006fd6;
	text-decoration: underline;
}

/* 아이콘 */
.icon-new {
	vertical-align: middle;
	margin-top: -5px;
	margin-left: 10px;
}

@media (max-width: 768px) {
	.icon-new {
		width: 16px;
		margin-top: -3px;
		margin-left: 6px;
	}
}

/**
 *	리스트
 */
/* 점이 있는 리스트 */
.dotted-list {
	color: #222;
	font-size: 16px;
	line-height: 1.8;
	letter-spacing: -0.04em;
	font-weight: 400;
}
.dotted-list li {
	position: relative;
	padding-left: 20px;
	word-break: keep-all;
	overflow-wrap: break-word;
	word-wrap: break-word;
}
.dotted-list li::before {
	content: "";
	position: absolute;
	top: 11px;
	left: 5px;
	width: 5px;
	height: 5px;
	background: #838383;
	border-radius: 50%;
}

@media (max-width: 768px) {
	.dotted-list {
		font-size: 13px;
	}
	.dotted-list li {
		padding-left: 14px;
	}
	.dotted-list li::before {
		width: 4px;
		height: 4px;
		top: 8px;
		left: 5px;
	}
}

/**
 *	박스 
 */
.text-box {
	background: #f3f5f9 url(../images/sub/visit_01_bg.png) no-repeat 0 100%;
	border: 1px solid #c3d9f2;
	margin-bottom: 30px;
	padding: 30px 40px;
}
.text-box .box-wrap {
	display: flex;
	align-items: center;
}
.text-box .box-icon {
	margin-right: 30px;
	flex: 0 0 130px;
	text-align: center;
}
.text-box .box-icon i {
	color: #267fd6;
	font-size: 56px;
}
.text-box .box-text {
	font-size: 16px;
	color: #2f6199;
	word-break: keep-all;
	overflow-wrap: break-word;
	word-wrap: break-word;
	letter-spacing: -0.024em;
	line-height: 1.5;
	flex: 1 1 auto;
}
.text-box .box-text p + p {
	margin-top: 8px;
}
.text-box .box-text p span {
	font-weight: 600;
}
.text-box .box-text .box-text-btn {
	text-decoration: underline;
	text-underline-position: under;
}

@media (max-width: 1024px) {
	.text-box .box-icon {
		flex-basis: 100px;
		margin-right: 30px;
	}
}
@media (max-width: 768px) {
	.text-box {
		padding: 20px 30px;
		margin-bottom: 20px;
	}
	.text-box .box-icon {
		display: none;
	}
	.text-box .box-text {
		font-size: 12px;
		width: 100%;
		font-weight: 400;
	}
	.text-box .box-text p + p {
		margin-top: 10px;
	}
}

/**
 *	탭
 */
.page-tab {
	margin-bottom: 50px;
}
.page-tab .tab-list {
	border-top: 1px solid #b7c0cb;
	border-left: 1px solid #b7c0cb;
	display: flex;
}
.page-tab .tab-list li {
	flex: 1;
	border-right: 1px solid #b7c0cb;
	border-bottom: 1px solid #b7c0cb;
}
.page-tab .tab-list li a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 75px;
	background: #fff;
	color: #4b4b4b;
	font-size: 24px;
	font-weight: 500;
	text-align: center;
	word-break: keep-all;
	padding: 0 15px;
}
.page-tab .tab-list li.on a {
	background: linear-gradient(to top, #0060cc 0%, #1582e8 98%);
	color: #fff;
	font-weight: 600;
}
.page-tab .tab-list li a:hover {
	font-weight: 600;
}

@media (max-width: 1024px) {
	.page-tab {
		margin-bottom: 30px;
	}
	.page-tab .tab-list li a {
		height: 60px;
		font-size: 18px;
	}
}
@media (max-width: 768px) {
	.page-tab {
		margin-bottom: 25px;
	}
	.page-tab .tab-list {
		flex-wrap: wrap;
	}
	.page-tab:not(.tab-full) .tab-list li {
		flex: 1 1 50%;
	}
	.page-tab .tab-list li a {
		height: 38px;
		font-size: 12px;
		padding: 0 5px;
	}
}

/*=========================================================================================================================================*/
/** 
 *  버튼
 */
.btn {
	display: inline-block;
	border-radius: 6px;
	text-align: center;
	cursor: pointer;
	white-space: nowrap;
	vertical-align: middle;
	box-shadow: none !important;
}
.btn.no-radius {
	border-radius: 0;
}

.btn.btn-right {
	position: absolute;
	top: -7px;
	right: 0;
}

/*** 버튼 - 채워진 형태 ***/
.btn.btn-background {
	min-width: 190px;
	height: 56px;
	padding: 0 25px;
	border: none;
	background: #666;
	color: #fff !important;
	font-size: 18px;
	line-height: 56px;
	font-weight: 500;
}
/* 크기*/
.btn.btn-background.btn-xsmall {
	min-width: 100px;
	padding: 0 16px;
	height: 38px;
	font-size: 15px;
	line-height: 38px;
}
.btn.btn-background.btn-small {
	min-width: 128px;
	padding: 0 30px;
	height: 48px;
	font-size: 18px;
	line-height: 48px;
}
/* 색상*/
.btn.btn-background.confirm, /* 확인 */
.btn.btn-background.regist, /* 등록 */
.btn.btn-background.list, /* 목록 */
.btn.btn-background.write,  /* 글쓰기 */
.btn.btn-background.search /* 검색 */ {
	background: #2b75cb;
}
.btn.btn-background.update,
.btn.btn-background.modify {
	background: #1582d6;
} /* 수정 */
.btn.btn-background.delete, /* 삭제 */
.btn.btn-background.cancel {
	background: #8d8d8d;
} /* 취소 */
.btn.btn-background.view {
	background: #2358d1;
} /* 사진으로 보기 */
.btn.btn-background.view i {
	margin-right: 5px;
}

/*** 버튼 - 라인 형태 ***/
.btn.btn-border {
	min-width: 70px;
	height: 56px;
	padding: 0 25px;
	border: 1px solid #666;
	background: #fff;
	color: #666;
	font-size: 18px;
	line-height: 54px;
}
/* 크기 */
.btn.btn-border.btn-small {
	min-width: 60px;
	padding: 0 12px;
	height: 30px;
	font-size: 12px;
	line-height: 28px;
}
.btn.btn-border.btn-large {
	min-width: 70px;
	height: 44px;
	padding: 0 25px;
	font-size: 16px;
	line-height: 42px;
}
.btn.btn-border.btn-xlarge {
	width: 100%;
	height: 44px;
	font-size: 16px;
	line-height: 44px;
}
/* 색상 */
.btn.btn-border.btn-blue {
	border-color: #649ed9;
}
.btn.btn-border.btn-green {
	border-color: #77c035;
}
.btn.btn-border.btn-gray {
	border-color: #8a8d91;
}
.btn.btn-border.btn-pink {
	border-color: #e58a9e;
}
.btn.btn-border.write {
	border-color: #1f6db1;
	color: #1f6db1;
} /* 쓰기 */
.btn.btn-border.search, /* 조회 */
.btn.btn-border.modify {
	border-color: #214b64;
	color: #214b64;
} /* 수정 */
.btn.btn-border.delete {
	border-color: #888;
	color: #888;
} /* 삭제 */
.btn.btn-border.close, /* 닫기 */
.btn.btn-border.cancel {
	border-color: #888;
	color: #888;
} /* 취소 */
.btn.btn-border.create, /* 생성 */
.btn.btn-border.list, /* 목록 */
.btn.btn-border.save, /* 저장 */
.btn.btn-border.select {
	border-color: #1f6db1;
	color: #1f6db1;
} /* 선택 */
.btn.btn-border.view {
	background: #f8fbfd;
	border-color: #cfcfcf;
	color: #2b75cb;
} /* 자세히보기 */
.btn.btn-border.view i {
	margin-left: 5px;
}

@media (max-width: 768px) {
	/* .btn{border-radius:2px;} */

	/*** 버튼 - 채워진 형태 ***/
	.btn.btn-background {
		min-width: 130px;
		height: 36px;
		line-height: 36px;
		font-size: 12px;
		padding: 0 20px;
		border-radius: 3px !important;
	}
	/* 크기 */
	.btn.btn-background.btn-xsmall {
		min-width: 60px;
		padding: 0 10px;
		height: 27px;
		font-size: 11px;
		line-height: 27px;
	}
	.btn.btn-background.btn-small {
		min-width: 86px;
		height: 32px;
		line-height: 32px;
		font-size: 12px;
		padding: 0 15px;
	}
	.btn.btn-border.view i {
		margin-left: 2px;
	}

	/*** 버튼 - 라인 형태 ***/
	.btn.btn-border {
		min-width: 120px;
		height: 36px;
		font-size: 13px;
		line-height: 32px;
	}
	/* 크기 */
	.btn.btn-border.btn-small {
		padding: 0 8px;
		font-size: 11px;
		height: 24px;
		line-height: 22px;
		min-width: 90px;
		font-size: 11px;
	}
}

/*=========================================================================================================================================*/
/** 
 *  버튼 그룹
 *	.btn-group: 버튼 그룹 기본 클래스
 *	.btn-group .left-group: 왼쪽 정렬 버튼 그룹
 *	.btn-group .right-group: 오른쪽 정렬 버튼 그룹
 *	.btn-group .center-group: 중앙 정렬 버튼 그룹
 */
.btn-group {
	display: table;
	width: 100%;
	table-layout: fixed;
	margin-top: 38px;
}
.btn-group.top {
	margin-top: 0;
	margin-bottom: 50px;
}

.btn-group [class$="group"] {
	display: table-cell;
	vertical-align: middle;
}
.btn-group .left-group {
	text-align: left;
}
.btn-group .right-group {
	text-align: right;
}
.btn-group .center-group {
	text-align: center;
}
.btn-group .left-group a,
.btn-group .left-group .btn {
	margin-right: 20px;
}
.btn-group .right-group a,
.btn-group .right-group .btn {
	margin-left: 20px;
}
.btn-group .center-group a,
.btn-group .center-group .btn {
	margin: 0 10px;
}

@media (max-width: 768px) {
	.btn-group {
		margin-top: 20px;
	}
	.btn-group.top {
		margin-bottom: 20px;
	}

	.btn-group .left-group a,
	.btn-group .left-group .btn {
		margin-right: 6px;
	}
	.btn-group .right-group a,
	.btn-group .right-group .btn {
		margin-left: 6px;
	}
	.btn-group .center-group a,
	.btn-group .center-group .btn {
		margin: 0 3px;
	}

	.board-list ~ .btn-group .right-group {
		text-align: center;
	}
}

/*=========================================================================================================================================*/
/** 
 *	폼요소
 */
/* placeholder */
::-webkit-input-placeholder {
	color: #818181;
}
:-moz-placeholder {
	color: #818181;
}
::-moz-placeholder {
	color: #818181;
}
:-ms-input-placeholder {
	color: #818181;
}

/* form 여백 */
* + .form-row {
	margin-top: 10px;
}

/* form 공통 */
input.inp-text,
input.inp-file,
select.sel,
textarea.txtarea {
	font-size: 16px;
	max-width: 100%;
	background-color: #fff;
	color: #222;
	border: 1px solid #a7a7a7;
	border-radius: 7px;
	vertical-align: middle;
}
input.inp-text,
input.inp-file,
select.sel {
	width: 286px;
	height: 46px;
}
input.inp-text.full,
input.inp-file.full,
select.sel.full {
	width: 100%;
}

/* input[type=text, password, number] */
input.inp-text {
	padding: 0 20px;
}
input.inp-text[readonly] {
	color: #a7a7a7;
	cursor: default;
}
input.inp-text[numberOnly] {
	text-align: right;
}
input.inp-text.datepicker {
	cursor: pointer;
	color: #515151;
	background: #fff url("../images/sub/icon_calendar.png") no-repeat right 10px top 50%;
}
input.inp-text::-webkit-outer-spin-button,
input.inp-text::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
} /* Chrome, Safari, Edge, Opera */
input.inp-text {
	-moz-appearance: textfield;
} /* Firefox */

/* input[type=file] */
input.file,
input.inp-file {
	padding: 2px 20px;
}

/* input[type=checkbox,radio] */
input.chk,
input.rdo {
	width: 1.2em;
	height: 1.2em;
	vertical-align: middle;
	font-size: inherit;
}
label.lbl + input.rdo,
label.lbl + input.chk {
	margin-left: 4px;
}

/* label */
label.lbl,
label.rdo-lbl,
label.chk-lbl {
	vertical-align: middle;
}
input.rdo + label.lbl,
input.chk + label.lbl {
	margin-left: 4px;
}

/* textarea */
textarea.txtarea {
	resize: none;
	width: 100%;
	padding: 15px 20px;
}

/* select box */
select.sel {
	padding: 0 16px;
}

/* disabled/readonly color */
input.inp-text[disabled],
select.sel[disabled],
textarea.txtarea[disabled] {
	background: #efefef !important;
}

/* focus color */
input.inp-text:focus,
input.inp-file:focus,
textarea.txtarea:focus,
select.sel:focus {
	border-color: #438de2;
	box-shadow: 0 0 2px rgba(0, 0, 0, 0.1);
}
input.inp-text[readonly]:focus,
input.inp-text[disabled]:focus,
select.sel[readonly]:focus,
select.sel[disabled]:focus {
	border-color: #a7a7a7;
}

/* 폼요소 너비 조정 */
div.form-control {
	width: 100%;
	max-width: 100%;
}
* + div.form-control:not(.horizonal) {
	margin-top: 10px;
}
div.form-control input.inp-text,
div.form-control input.inp-file,
div.form-control select.sel {
	width: 100%;
}

span.form-control {
	display: inline-block;
	max-width: 100%;
	margin: 2px 15px 2px 0;
	vertical-align: middle;
}
span.form-control:last-child {
	margin-right: 0;
}
.lbl + span.form-control {
	margin-left: 5px;
}
span.form-control .text + input.inp-text,
span.form-control .text + select.sel,
span.form-control .lbl + input.inp-text,
span.form-control .lbl + select.sel {
	margin-left: 4px;
}
span.form-control input.inp-text + .text,
span.form-control select.sel + .text {
	margin-left: 3px;
}
span.form-control .bul {
	margin: 0 5px;
}
span.form-control .btn + .btn {
	margin-left: 3px;
}
/* span.form-control .inp-text + .btn{margin-left:6px;} */
span.form-control .text {
	vertical-align: middle;
	line-height: 28px;
	font-weight: 500;
}
span.form-control .text + .text {
	margin-left: 20px;
}
span.form-control .text strong {
	/* font-size:14px; */
	font-weight: 500;
	margin-right: 3px;
}
.bul {
	font-size: 14px;
	font-weight: 500;
	margin: 0 2px;
	vertical-align: middle;
}

.form-control.horizonal {
	display: inline-block;
	width: auto;
	margin: 2px 5px 2px 0;
	vertical-align: middle;
}
.form-control.no-radius * {
	border-radius: 0 !important;
}
.form-control.control-center {
	margin-left: auto;
	margin-right: auto;
}

/* 버튼이 있는 폼요소 */
div.form-control.with-btn {
	display: flex;
}
div.form-control.with-btn .btn {
	flex: 0 0 auto;
	margin-left: 8px;
	margin-right: 0;
}
div.form-control.with-btn-search {
	position: relative;
	padding-right: 115px;
}
div.form-control.with-btn-search .btn {
	position: absolute;
	top: 0;
	right: 0;
	width: 110px;
	padding-left: 0;
	padding-right: 0;
}
div.form-control .btn {
	margin-right: 3px;
}

/* 날짜 아이콘이 있는 폼요소 */
.form-control.date {
	position: relative;
	width: 147px;
	padding-right: 27px;
}
/* .form-control.date .inp-text{text-align:center;} */
.form-control.date img {
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -12px;
	cursor: pointer;
}

/* 이메일 */
div.form-control.email {
	*zoom: 1;
}
div.form-control.email::after {
	content: "";
	display: block;
	clear: both;
}
div.form-control.email .inp-text {
	float: left;
	width: 32%;
}
div.form-control.email .email-at {
	float: left;
	width: 4%;
	height: 100%;
	margin-top: 10px;
	text-align: center;
}
div.form-control.email select {
	float: left;
	width: 31%;
	margin-left: 1%;
}
div.form-control.email.no-select .inp-text {
	width: 47%;
}
div.form-control.email.no-select .email-at {
	width: 6%;
}

/* 전화번호 */
div.form-control.phone {
	*zoom: 1;
}
div.form-control.phone::after {
	content: "";
	display: block;
	clear: both;
}
div.form-control.phone select {
	float: left;
	width: 30%;
}
div.form-control.phone .phone-bar {
	float: left;
	width: 5%;
	height: 100%;
	margin-top: 6px;
	font-size: 20px;
	text-align: center;
	line-height: 1;
}
div.form-control.phone .inp-text {
	float: left;
	width: 30%;
}

/* 생년월일 */
div.form-control.birthday {
	display: flex;
}
div.form-control.birthday.horizonal {
	display: inline-flex;
}
div.form-control.birthday .sel + .sel {
	margin-left: 10px;
}

/* 주민등록번호 */
div.form-control.reg-num {
	*zoom: 1;
}
div.form-control.reg-num::after {
	content: "";
	display: block;
	clear: both;
}
div.form-control.reg-num .bar {
	float: left;
	width: 5%;
	text-align: center;
	line-height: 46px;
}
div.form-control.reg-num .inp-text {
	float: left;
	width: 47.5%;
}

/** form-control 크기 **/
.form-control.number {
	width: 75px;
}
.form-control.xsmall {
	width: 120px;
}
.form-control.small {
	width: 240px;
}
.form-control.medium {
	width: 360px;
}
.form-control.large {
	width: 480px;
}
.form-control.xlarge {
	width: 600px;
}
.form-control.date {
	width: 200px;
}

/* 라벨이 있는 폼요소 */
.form-control.with-label {
	position: relative;
	padding-left: 60px;
}
.form-control.with-label .lbl {
	position: absolute;
	left: 0;
	top: 50%;
	width: 60px;
	color: #3f3f3f;
	font-size: 14px;
	font-weight: 500;
	transform: translateY(-50%);
}
.form-control.with-label .rdo + .lbl,
.form-control.with-label .chk + .lbl {
	position: static;
	width: auto;
	font-weight: 400;
}
/* 라벨이 길 경우 */
.form-group.label .form-control {
	position: relative;
	padding-left: 100px;
}
.form-group.label .form-control .lbl {
	position: absolute;
	left: 0;
	top: 50%;
	width: 100px;
	color: #3f3f3f;
	font-size: 14px;
	font-weight: 500;
	transform: translateY(-50%);
}

@media (max-width: 1024px) {
	input.inp-text,
	input.inp-file,
	select.sel,
	textarea.txtarea {
		font-size: 15px;
	}
	input.inp-text,
	input.inp-file,
	select.sel {
		height: 42px;
	}

	input.inp-text {
		padding: 0 15px;
	}
	textarea.txtarea {
		padding: 10px 15px;
	}
	select.sel {
		padding: 0 11px;
	}
}
@media (max-width: 768px) {
	div.form-control:not(.horizonal) + div.form-control:not(.horizonal) {
		margin-top: 5px;
	}
	div.form-control.with-btn .btn {
		margin-left: 4px;
	}
	div.form-control.email .email-at {
		margin-top: 8px;
	}

	* + .form-row {
		margin-top: 5px;
	}

	input.inp-text,
	input.inp-file,
	select.sel,
	textarea.txtarea {
		font-size: 13px;
		border-radius: 3px;
	}
	input.inp-text,
	input.inp-file,
	select.sel {
		height: 31px;
	}

	input.inp-text {
		padding: 0 10px;
	}
	input.inp-text.datepicker {
		background-size: 16px auto;
		background-position: right 8px top 50%;
	}
	textarea.txtarea {
		padding: 6px 10px;
	}
	select.sel {
		padding: 0 8px;
	}
}
@media (max-width: 520px) {
	div.form-control.email .inp-text {
		width: 47%;
	}
	div.form-control.email .email-at {
		width: 6%;
	}
	div.form-control.email select {
		width: 100%;
		margin-left: 0;
		margin-top: 5px;
	}
}

/** 
 *  테이블
 */
table {
	width: 100%; /* table-layout:fixed; */
	letter-spacing: -0.04em;
}
table.text-left th,
table.text-left td {
	text-align: left;
}
table.text-center th,
table.text-center td {
	text-align: center;
}
table th.text-center,
table td.text-center {
	text-align: center !important;
}
table th.text-left,
table td.text-left {
	text-align: left !important;
}
table th.text-right,
table td.text-right {
	text-align: right !important;
}

/**
 *	Modal
 */
.modal {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1000;
}
.modal.on {
	display: block;
}
.modal .modal-wrap {
	overflow: hidden;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 540px;
	max-width: 90%;
	margin: 0 auto;
	z-index: 1001;
	background: #fff;
	border-radius: 23px;
	transform: translate3d(-50%, -50%, 0);
	word-break: keep-all;
	word-wrap: break-word;
	animation: 0.3s fadeIn;
}
.modal .modal-wrap.wrap-medium {
	width: 640px;
}
.modal .modal-wrap.wrap-large {
	width: 868px;
}

.modal .modal-head {
	position: relative;
	background: #18569e;
	text-align: center;
	padding: 21px 20px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.modal .modal-title {
	color: #fff;
	font-size: 22px;
	font-weight: bold;
	line-height: 1.35;
}
.modal .modal-body {
	overflow-y: auto;
	max-height: 360px;
	max-height: calc(100vh - 200px);
}
.modal .modal-contents {
	background: #e8edf3;
	padding: 30px 40px;
	text-align: center;
}
.modal .modal-contents-title {
	margin-bottom: 14px;
	font-size: 20px;
	color: #4a4a4a;
	font-weight: 600;
}
.modal .modal-section {
	padding: 0 15px;
}
.modal .modal-section + .modal-section {
	margin-top: 25px;
	padding-top: 25px;
	border-top: 1px solid #b0c4dc;
}
.modal .modal-text {
	margin-bottom: 30px;
	color: #515151;
	font-size: 18px;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
}
.modal * + .modal-text {
	margin-top: 30px;
	margin-bottom: 0;
}
.modal .modal-desc {
	color: #18569e;
	font-size: 15px;
	font-weight: 500;
	text-align: left;
	margin-top: 10px;
}
.modal .btn-wrap {
	text-align: right;
	margin-bottom: 8px;
}
.modal .btn-wrap.center {
	text-align: center;
	margin-top: 10px;
}
.modal .modal-text + .btn-wrap {
	margin-top: -30px;
}
.modal .inp-text {
	width: 293px;
	max-width: 100%;
	height: 46px;
	color: #515151;
	font-size: 16px;
	border: 1px solid #18569e;
	border-radius: 7px;
}
.modal .inp-text[type="password"] {
	text-align: center;
}
.modal .form-control.with-btn .inp-text {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}
.modal .form-control.with-btn .btn {
	background: #18569e;
	color: #fff;
	margin: 0;
	padding: 0 25px;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	font-size: 16px;
}
.modal .modal-button {
	padding: 22px 0;
	text-align: center;
}
.modal .modal-button .btn {
	margin: 0 3px;
	height: 34px;
	line-height: 34px;
	min-width: 79px;
	border-radius: 8px;
	font-size: 14px;
}
.modal .modal-button .btn.confirm {
	background: linear-gradient(to bottom, rgba(71, 114, 177, 1) 0%, rgba(66, 94, 164, 1) 100%);
} /* 적용, 등록 */
.modal .modal-button .btn.cancel {
	background: linear-gradient(to bottom, rgba(149, 149, 149, 1) 0%, rgba(108, 108, 108, 1) 100%);
}
.modal .modal-bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1000;
	background: rgba(0, 0, 0, 0.45);
}
.modal .btn-modal-close {
	position: absolute;
	top: 22px;
	right: 20px;
	width: 30px;
	height: 30px;
	color: #fff;
	font-size: 26px;
	line-height: 1;
}
.modal .btn-modal-close i {
	line-height: 1;
	vertical-align: top;
}

.modal .app-down {
	display: flex;
	justify-content: center;
}
.modal .app-down a {
	display: inline-block;
	background: #fff;
	height: 60px;
	padding: 10px 15px;
	border-radius: 10px;
	border: 1px solid #cedae3;
	color: #4a4a4a;
	font-size: 16px;
	font-weight: 600;
	width: 50%;
}
.modal .app-down a .icon {
	float: left;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: 100% auto;
}
.modal .app-down a span {
	line-height: 39px;
}
.modal .app-down .btn-android {
	margin-right: 15px;
}
.modal .app-down .btn-android .icon {
	width: 32px;
	height: 39px;
	background-image: url("../images/sub/icon_android.png");
}
.modal .app-down .btn-ios .icon {
	width: 40px;
	height: 39px;
	background-image: url("../images/sub/icon_ios.png");
}

@media (max-width: 768px) {
	.modal .modal-wrap {
		width: 400px;
	}
	.modal .modal-head {
		/* height:50px; */
		padding: 15px 20px;
	}
	.modal .modal-title {
		font-size: 16px;
	}
	.modal .modal-contents {
		padding: 20px 25px;
	}
	.modal .modal-contents-title {
		font-size: 15px;
		margin-bottom: 10px;
	}
	.modal .modal-section {
		padding: 0 10px;
	}
	.modal .modal-section + .modal-section {
		margin-top: 15px;
		padding-top: 15px;
	}
	.modal .modal-text {
		font-size: 13px;
		margin-bottom: 20px;
	}
	.modal .modal-desc {
		font-size: 12px;
	}
	.modal .inp-text {
		height: 38px;
		width: 240px;
		font-size: 13px;
		border-radius: 3px;
	}
	.modal .form-control.with-btn .btn {
		font-size: 13px;
		padding: 0 15px;
	}
	.modal .modal-button {
		padding: 12px 0;
	}
	.modal .modal-button .btn {
		height: 30px;
		line-height: 30px;
		font-size: 12px;
		min-width: 70px;
	}
	.modal .btn-modal-close {
		top: 10px;
		font-size: 22px;
	}

	.modal .app-down a {
		height: 44px;
		padding: 7px 10px;
		font-size: 14px;
	}
	.modal .app-down a span {
		line-height: 28px;
	}
	.modal .app-down .btn-android {
		margin-right: 10px;
	}
	.modal .app-down .btn-android .icon {
		width: 22px;
		height: 28px;
	}
	.modal .app-down .btn-ios .icon {
		width: 29px;
		height: 28px;
	}
}

/*=========================================================================================================================================*/

/**
 *	팝업 
 */
.popup-wrap {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	color: #333;
	font-size: 14px;
	/* padding-bottom: 37px; */
}
.popup-wrap .popup-body {
	height: 100%;
	overflow-y: auto;
}
.popup-wrap .popup-body img {
	display: block;
}
.popup-wrap .body-contents {
	padding: 10px 15px;
}
.popup-wrap .popup-bottom {
	position: absolute;
	top: 100%;
	left: -1px;
	right: -1px;
	height: 37px;
	padding: 8px 15px;
	border-top: 1px solid #ccc;
	background-color: #fbf9fa;
	color: #444;
	font-size: 13px;
	font-weight: 500;
}
.popup-wrap .popup-bottom::after {
	content: "";
	display: block;
	clear: both;
}
.popup-wrap .popup-bottom .left-area {
	float: left;
}
.popup-wrap .popup-bottom .right-area {
	float: right;
}
.popup-wrap .popup-bottom .today-chk,
.popup-wrap .popup-bottom .today-lbl {
	vertical-align: middle;
}
.popup-wrap .popup-bottom .today-lbl {
	margin-left: 4px;
}
.popup-wrap .popup-bottom .popup-close {
	width: 30px;
	height: 20px;
	border: none;
	background-color: transparent;
	font-size: 13px;
	font-weight: 500;
}
/* 레이어 */
.popup-layer {
	position: absolute;
	z-index: 990;
	outline: 1px solid #ccc;
	background: #fff;
	max-height: calc(100vh - 60px);
}
.popup-layer.layer-center {
	top: 50% !important;
	left: 50% !important;
	transform: translate3d(-50%, -50%, 0);
}

@media (max-width: 1024px) {
	.popup-layer,
	.popup-layer.layer-center {
		top: 50% !important;
		left: 50% !important;
		transform: translate3d(-50%, -50%, 0);
	}
}
@media (max-width: 768px) {
	.popup-layer,
	.popup-layer.layer-center {
		top: 30px !important;
		left: 20px !important;
		right: 20px !important;
		transform: none;
		margin: 0 auto;
	}
}
@media (max-width: 480px) {
	.popup-layer {
		width: auto !important;
		max-width: 90%;
	}
	.popup-layer img {
		width: 100%;
	}
}


.vc-weekday {color:#000 !important;}