:root {
	--color-blue: rgba(22, 88, 222, 0.2);
	--color-blue-2: #006EB5;
	--color-gray: rgba(88, 88, 88, 0.2);
	--color-green: rgba(88, 222, 88, 0.2);
	--color-red: rgba(222, 88, 88, 1);
	--color-white: rgba(255, 255, 255, 1);
	--color-yellow: rgba(222, 222, 88, 0.2);

	--bc-red: rgba(222, 88, 22, 1);
	--bc-blue: rgba(22, 88, 222, 1);
	--bc-yellow: rgba(222, 222, 88, 1);

	--font-size-default: calc(8px + 0.2vw + 0.2vh);
	--font-size-2: calc(8px + 0.4vw + 0.4vh);
	--font-size-3: calc(8px + 0.8vw + 0.8vh);
	--font-size-4: calc(8px + 2.2vw + 2.2vh);
}


@font-face {
	font-family: "NotoSansKR";
	src: url("/font/NotoSansKR.woff2") format("woff2");
	/*font-display: swap;*/
}


@font-face {
	font-family: "PretendardVariable";
	src: url("/font/PretendardVariable.woff2") format("woff2");
	/*font-display: swap;*/
}


@font-face {
	font-family: "MaruBuri";
	src: url("/font/MaruBuri.woff2") format("woff2");
	/*font-display: swap;*/
}


@font-face {
	font-family: "MaruBuri-SemiBold";
	src: url("/font/MaruBuri-SemiBold.woff2") format("woff2");
	/*font-display: swap;*/
}


@font-face {
	font-family: "NanumMyeongjo";
	src: url("/font/NanumMyeongjo.woff2") format("woff2");
	/*font-display: swap;*/
}


.fs-default {
	font-size: var(--font-size-default) !important;
}


.fs-2 {
	font-size: var(--font-size-2) !important;
}


.fs-3 {
	font-size: var(--font-size-3) !important;
}


.fs-4 {
	font-size: var(--font-size-4) !important;
}


.fs-8 {
	font-size: 8px !important;
}


.fs-9 {
	font-size: 9px !important;
}


.fs-10 {
	font-size: 10px !important;
}


.fs-11 {
	font-size: 11px !important;
}


.fs-12 {
	font-size: 12px !important;
}


.fs-13 {
	font-size: 13px !important;
}


.fs-14 {
	font-size: 14px !important;
}


.fs-15 {
	font-size: 15px !important;
}


.fs-16 {
	font-size: 16px !important;
}


.fs-17 {
	font-size: 17px !important;
}


.fs-18 {
	font-size: 18px !important;
}


.fs-19 {
	font-size: 19px !important;
}


.fs-20 {
	font-size: 20px !important;
}


.fs-21 {
	font-size: 21px !important;
}


.fs-22 {
	font-size: 22px !important;
}


.d-b {
	display: block;
}


.d-f {
	display: flex;
	align-items: center;
}


.w-f {
	width: fit-content;
}


.jc-fe {
	justify-content: flex-end;
}


.jc-sb {
	justify-content: space-between;
}


.color-red {
	color: var(--color-red) !important;
}


.color-blue {
	color: var(--color-blue) !important;
}


.color-blue-2 {
	color: var(--color-blue-2) !important;
}


.bc-red {
	background-color: var(--bc-red) !important;
	color: rgba(255, 255, 255, 1) !important;
}


.bc-blue {
	background-color: var(--bc-blue) !important;
	color: rgba(255, 255, 255, 1) !important;
}


.bc-yellow {
	background-color: var(--bc-yellow) !important;
	color: rgba(255, 255, 255, 1) !important;
}


.bc-gray {
	background-color: rgba(88, 88, 88, 0.2) !important;
}


* {
	scroll-behavior: smooth;
	box-sizing: border-box;
	font-family: "NotoSansKR";
	font-size: var(--font-size-default);
	-webkit-tap-highlight-color: transparent;
}


caption {
	margin: 8px 0;
}


.caption-wrapper {
	margin: 8px 0;
}


.active-page {
	color: #0062b5;
	font-weight: 800;
}


.td-underline {
	text-decoration: underline;
}


em {
	font-style: normal;
}


.ta-left {
	text-align: left;
}


.ta-center {
	text-align: center;
}


.ta-right {
	text-align: right;
}


.fw-200 {
	font-weight: 200 !important;
}


.fw-300 {
	font-weight: 300 !important;
}


.fw-400 {
	font-weight: 400 !important;
}


.fw-500 {
	font-weight: 500 !important;
}


.fw-600 {
	font-weight: 600 !important;
}


.fw-700 {
	font-weight: 700 !important;
}


.fw-800 {
	font-weight: 800 !important;
}


.tw-balance {
	text-wrap: balance;
}


.display-flex-1 {
	align-items: center;
	display: flex;
	justify-content: space-between;
}


.br-8px {
	border-radius: 8px;
}


.border-1 {
	border: 1px solid rgba(222, 222, 222, 1);
}


.margin-8px {
	margin: 8px;
}


.padding-8px {
	padding: 8px !important;
}


.mb-8px {
	margin-bottom: 8px;
}


.mt-8px {
	margin-top: 8px;
}


html, body {
	min-height: 100dvh;
	margin: 0;
	display: flex;
	flex-direction: column;
	/*min-height: 0;*/
}


body {


}


main {
	flex: 1;
	overflow: auto;
	min-height: 0;
}


.mobile {
	display: none;
}


.mobile-menu-wrapper {
	display: none;
}


input::-webkit-inner-spin-button {
	display: none;
}


input:-webkit-autofill { /* input 태그 자동완성 색상 제거 */
	box-shadow: #fff 0 0 0 1000px inset;

	outline-style: none;
}


input[type=submit] {
	cursor: pointer;
}


a {
	color: rgba(0, 0, 0, 1);
	text-decoration: none;
}


textarea[readonly] {
	resize: none;
}


textarea::-webkit-scrollbar {
	display: none;
}


input[type=date]::-webkit-calendar-picker-indicator {
	display: none;
}


input {
	outline-style: none;
	min-width: 0;
}


input, textarea, button {
	border: 1px solid rgba(222, 222, 222, 1);
}


.mobile {
	display: none;
}


.page-list {
	margin: 22px auto;
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 88%;
}


.page-list > a {
	font-size: var(--font-size-2);
	padding: 0 8px;
	margin: 0 2px;
}


.d-n {
	display: none !important;
}


.hidden {
	left: -88888888px;
	position: absolute;
}


.pe-none {
	/*border-style: none;*/
	pointer-events: none;
}


.fade-in {
	-webkit-animation: fade-in 0.2s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
	animation: fade-in 0.2s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
	display: block !important;
}


.disable-link {
	color: rgba(222, 222, 222, 1);
	pointer-events: none;
}


input[type=submit], button {
	background-color: #006EB5;
	color: rgba(255, 255, 255, 1);
	cursor: pointer;
	padding: 8px;
}


.td-left {
	text-align: left !important;
}


.td-center {
	text-align: center !important;
}


.td-right {
	text-align: right !important;
}


.modal-container {
	background-color: rgba(88, 88, 88, 1);
	height: 100vh;
	left: 0;
	position: fixed;
	top: 0;
	width: 100vw;
	z-index: 22;
}


.modal-wrapper {
	backdrop-filter: blur(8px);
	background-color: rgba(255, 255, 255, 1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	box-shadow: 0px 0px 8px 2px rgba(88, 88, 88, 1);
	height: 88%;
	left: 50%;
	overflow-y: auto;
	padding: 0 8px;
	position: fixed;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 88%;
}


.modal-content {
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 88%;
}


.modal-close-btn {
	cursor: pointer;
	font-size: var(--font-size-3);
	font-weight: 800;
	padding: 2px;
	position: sticky;
	top: 8px;
	left: 100%;
	width: fit-content;
	height: auto;
	display: flex;
	justify-content: flex-end;
}


.mr-8px {
	margin-right: 8px !important;
}


.ml-8px {
	margin-left: 8px !important;
}


.hyphen {
	display: inline-block;
	transform: rotate(90deg);
	margin: 0 8px;
}


.loading-spinner {
	position: fixed;
	top: 50%;
	left: 50%;
	z-index: 88;
	transform: translate(-50%, -50%);
	width: 100vw;
	height: 100vh;
	background-color: rgba(88, 88, 88, 0.8);
}


.loading-spinner > img {
	top: 50%;
	left: 50%;
	position: fixed;
	transform: translate(-50%, -50%);
}


ol, ul {
	margin: 0;
	padding: 0;
}


/*  테이블 공통 설정 시작  */

table {
	border-collapse: collapse;
}


th {
	font-size: var(--font-size-2);
	padding: 8px;
}


/*  테이블 공통 설정 종료  */


/*  결과 테이블 관련 설정 시작  */


.table-container {
	width: 80%;
	height: 80%;
	margin: 0 auto;
}


.table-wrapper {
	width: 100%;
	height: 80%;
	overflow: auto;
}


.data-table {
	width: 100%;
	white-space: nowrap;
}


.data-table thead {
	position: sticky;
	top: 0;
}


.data-table tfoot {
	position: sticky;
	bottom: 0;
}


.data-table tfoot > tr > td {
	border: none !important;
}


/*  결과 테이블 관련 설정 종료  */


@-webkit-keyframes fade-in {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}


@keyframes fade-in {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}


.table-list:hover {
	cursor: pointer;
	background-color: rgba(88, 88, 88, 0.2);
}


.table-list td {
	padding: 8px;
}


/* Layer Popup */
.layer-pop-up-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0, 0, 0, 0.7);
	z-index: 9999;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	padding: 20px;
}


.layer-pop-up-wrapper {
	background: white;
	border-radius: 16px;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
	max-width: 400px;
	width: 80%;
	height: auto;
}


.layer-pop-up-header {
	background: white;
	padding: 16px 20px;
	border-radius: 16px 16px 0 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}


.layer-pop-up-title {
	font-weight: 600;
	color: #2d3748;
}


.layer-pup-up-close-btn {
	background: #e53e3e;
	color: white;
	border: none;
	padding: 8px 12px;
	border-radius: 6px;
	cursor: pointer;
	font-weight: 600;
}


.layer-pop-up-content img {
	width: 100%;
	display: block;
}


.layer-pop-up-footer {
	background: white;
	padding: 16px 20px;
	border-radius: 0 0 16px 16px;
	text-align: center;
}


.layer-pop-up-one-day-close-btn {
	background: #e53e3e;
	color: white;
	border: none;
	padding: 12px 24px;
	border-radius: 8px;
	cursor: pointer;
	font-weight: 600;
	width: 100%;
}


/*
*::-webkit-scrollbar {
	width: 4px;
}

*::-webkit-scrollbar-track {
	background: #f1f1f1;
}

*::-webkit-scrollbar-thumb {
	background: #888;
	border-radius: 4px;
}

*::-webkit-scrollbar-thumb:hover {
	background: #555;
}*/
