/*@import url('//fonts.googleapis.com/css2?family=Inconsolata&display=swap');*/
/*@import url('//fonts.googleapis.com/css2?family=IBM+Plex+Mono&display=swap');*/
@import url('//fonts.googleapis.com/css2?family=Roboto+Mono&display=swap');
@import url('/assets/css/noonnu.fonts.css');
@import url('/assets/css/animate.min.css');



@property --angle {
	syntax: '<angle>';
	initial-value: 90deg;
	inherits: true;
}

@property --gradX {
	syntax: '<percentage>';
	initial-value: 50%;
	inherits: true;
}

@property --gradY {
	syntax: '<percentage>';
	initial-value: 0%;
	inherits: true;
}

:root {
	--d: 2500ms;
	--angle: 90deg;
	--gradX: 100%;
	--gradY: 50%;
	--c1: rgba(24, 106, 59, 1);
	--c2: rgba(171, 235, 198, 0.3);
}

.border-animation {
	border: 0.3rem solid;
	border-image: conic-gradient(from var(--angle), var(--c2), var(--c1) 0.1turn, var(--c1) 0.15turn, var(--c2) 0.25turn) 30;
	animation: borderRotate var(--d) linear infinite forwards;
}

@keyframes borderRotate {
	100% {
		--angle: 420deg;
	}
}

@keyframes borderRadial {
	20% {
		--gradX: 100%;
		--gradY: 50%;
	}
	40% {
		--gradX: 100%;
		--gradY: 100%;
	}
	60% {
		--gradX: 50%;
		--gradY: 100%;
	}
	80% {
		--gradX: 0%;
		--gradY: 50%;
	}
	100% {
		--gradX: 50%;
		--gradY: 0%;
	}
}

[role="pad-spaces"] [role="space-phase"] {
	--border-size: 0.3rem;
	border: var(--border-size) solid transparent;
}

[role="pad-spaces"] [role="space-phase"].rainbow {
	--border-size: 0.3rem;
	border: var(--border-size) solid transparent;

	/* Paint an image in the border */
	border-image: conic-gradient(
	from var(--angle),
	#d53e33 0deg 90deg,
	#fbb300 90deg 180deg,
	#377af5 180deg 270deg,
	#399953 270deg 360deg
	)
	1 stretch;
}

[role="pad-spaces"] .dropdown-menu {
	min-width: 1rem;
	padding: 0;
	border: 0.35rem solid rgba(163, 140, 198, 0.5);
	/* border-radius: 4px; */
}
[role="pad-spaces"] .dropdown-menu .dropdown-item {
	padding: 0.75rem 0.5rem;
}

/* Animate when Houdini is available */
@supports (background: paint(houdini)) {
	@property --opacity {
	syntax: "<number>";
	initial-value: 0.5;
	inherits: false;
	}

	@property --angle {
	syntax: "<angle>";
	initial-value: 0deg;
	inherits: false;
	}

	@keyframes opacityChange {
	to {
	--opacity: 1;
	}
	}

	@keyframes rotate {
	to {
	--angle: 360deg;
	}
	}

	.rainbow {
	animation: rotate 4s linear infinite, opacityChange 3s infinite alternate;
	}
}


ruby {
	display: contents;
	width: 100%;
}
panel, action, row, datetime, data {
	display: block;
}

.modal .row {
    margin-right: -0.25rem;
    margin-left: -0.25rem;
}

body, .app {
	position: relative;
	font-family: 'Pretendard-Regular';
	/*font-family: 'Noto Sans KR', sans-serif;*/
}
.app .mono {
	/*font-family: 'Inconsolata', monospace;*/
	/*font-family: 'IBM Plex Mono', monospace;*/
	font-family: 'Roboto Mono', monospace;
	/*font-size: 0.925rem;*/
	font-weight: 500;
}

.app .header-btn[data-class="mobile-nav-on"] {
    width: 2.875rem;
    margin-left: 1rem;
}

.app ul,
.app ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

.app [role="loader"] {
	position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.3);
	z-index: 9999;
}
.app [role="loader"] > div {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
	
.app .table th, .table td {
    vertical-align: middle;
}
.app .table th {
    text-align: center;
}

.app .text-center {
	text-align: center;
}

.app .text-right {
	text-align: right;
}

.app .pagination .active > page[data-url] {
	cursor: default;
}
.app .pagination page[data-url] {
    min-width: 32px;
    padding: 5px 10px;
    font-style: normal;
    line-height: 20px;
    /*color: var(--color-fg-default);*/
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    cursor: pointer;
    -webkit-user-select: none;
    user-select: none;
    border: 1px solid transparent;
    border-radius: 6px;
    transition: border-color .2s cubic-bezier(0.3, 0, 0.5, 1);
}
.app .pagination .page-item:first-child:not(.active) .page-link,
.app .pagination .page-item:last-child:not(.active) .page-link {
    background: transparent;
}

.custom-switch .custom-control-label::before {
    left: -2.46875rem;
    width: 1.96875rem;
    pointer-events: all;
    border-radius: 0.5625rem;
}
.custom-control-input:checked ~ .custom-control-label::before {
    color: #fff;
    border-color: #4679cc;
    background-color: #4679cc;
}

.app .auth-form {
    width: 340px;
    margin: 0 auto;
}

.app .auth-form-header {
    margin-bottom: 16px;
    color: var(--color-fg-default);
    text-align: center;
    text-shadow: none;
    background-color: transparent;
    border: 0;
}
.auth-form-header h1 {
    font-size: 24px;
    font-weight: 300;
    letter-spacing: -0.5px;
}

.app .auth-form-body {
    padding: 16px;
    font-size: 14px;
    background-color: var(--color-canvas-subtle);
    border: 1px solid var(--color-border-muted);
    border-top: 0;
	border-top: 1px solid var(--color-border-muted);
    border-radius: 0 0 6px 6px;
	border-radius: 6px;
}

.app .auth-form label {
    display: block;
    margin-bottom: 8px;
    font-weight: 400;
    text-align: left;
}
.app .auth-form .btn {
    margin-top: 16px;
}

.app .auth-form-body .input-block {
    margin-top: 4px;
    margin-bottom: 16px;
}

.app .login-callout {
    padding: 16px 16px;
    text-align: center;
    border: 1px solid var(--color-border-default);
    border-radius: 6px;
}

.app .page-sidebar,
.app .page-logo {
	width: 14.0rem;
}

.anchor {
	cursor: pointer;
}

.app .select2-container {
    z-index: 2090;
}

.form-control:disabled, .form-control[readonly] {
    background-color: #ddd;
    opacity: 1;
}

.sensor-manual {
    color: transparent!important;
    text-shadow: 0 0 2px rgb(0 0 0 / 50%);
}
.app .io-1 {
	color : #fd3995;
}

/* https://developer.mozilla.org/ko/docs/Web/CSS/Attribute_selectors */
.app [role*="preview"] img {
	max-width: 100%;
}

.mb-7, .my-7 {
	margin-bottom: 3.0rem !important;
}
.mb-8, .my-8 {
	margin-bottom: 3.5rem !important;
}
.progress:last-child.mb-7,
.progress:last-child.mb-8 {
	margin-bottom: 0 !important;
}


input[type=search]::-webkit-search-cancel-button{
}

[role="zipcode"] [role="result"] [role="address"] {
	cursor: pointer;
}
[role="zipcode"] [role="result"] address {
	display: unset;
}

.toast-center-center {
	position: absolute;
	top: 50%;
	right: 0;
	width: 100%;
}
#toast-container > .toast,
#toast-container.toast-top-center > div, #toast-container.toast-center-center > div, #toast-container.toast-bottom-center > div {
	width: 25rem;
}
#toast-container.toast-center-center > div {
	width: auto;
	margin-left: auto;
	margin-right: auto;
}

.alert-danger {
	color: #fff;
	background-color: #DE3163;
	border: 1px solid #DE3163;
}
.alert-warning {
	color: #fff;
	background-color: #FF7F50;
	border: 1px solid #FF7F50;
}
.alert-attention {
	color: #212529;
	background-color: #FFBF00;
	border: 1px solid #FFBF00;
}

.input-number, .input-natural, .input-decimal {
	text-align: right;
}

.mod-skin-dark:not(.mod-skin-light) svg[data-name="avatar-user"] path {
	fill: #fff;
}

.btn-switch.active
{
    color: #fff;
    background: #4679cc!important;
}

/*
https://kasumil.tistory.com/193
https://blog.jaeyoon.io/2017/10/js-datepicker.html

https://css-tricks.com/almanac/properties/a/appearance/

https://stackoverflow.com/questions/29436074/change-date-input-triangle-to-a-calendar-icon

https://stackoverflow.com/questions/11320615/disable-native-datepicker-in-google-chrome

https://developer.mozilla.org/en-US/docs/Web/CSS/background-attachment */
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
   color: rgba(0, 0, 0, 0); /*숨긴다*/
   opacity: 1;
   display: block;
   background-image: url(/static/calendar.svg); /* 대체할 아이콘*/
   background-repeat: no-repeat;
   background-size: cover;
   width: 24px;
   height: 24px;
   border-width: thin;
}

.common-modal-top-transparent .nav-tabs .nav-item .nav-link.active:not(:hover),
.common-modal-top-transparent .nav-tabs-clean .nav-item .nav-link:hover {
    background: 0 0;
    color: #fff!important
}

.common-modal-top-transparent .nav-tabs .nav-item.show .nav-link,
.common-modal-top-transparent .nav-tabs .nav-link.active {
    background: 0 0
}

.common-modal-top-transparent .nav-tabs:not(.nav-tabs-clean) .nav-item.show .nav-link,
.common-modal-top-transparent .nav-tabs:not(.nav-tabs-clean) .nav-link.active {
    border-color: rgba(255,255,255,.15) rgba(255,255,255,.15) rgb(49 57 71);
}

.common-modal-top-transparent .nav-tabs {
    border-bottom-color: rgba(255,255,255,.15);
}

.common-modal-top-transparent .nav-tabs .nav-link:not(.active):focus,
.common-modal-top-transparent .nav-tabs .nav-link:not(.active):hover {
    border-color: rgba(255,255,255,.07) rgba(255,255,255,.07) transparent
}

.common-modal-top-transparent .tab-content.border {
    border-color: rgba(255,255,255,.15)!important
}

.common-modal-top-transparent .modal-header .close {
    padding: 1.25rem 1.25rem;
    margin: -0.7rem 0 -1.25rem;;
}

.modal-backdrop.show {
    opacity: 0.8;
}


@media only screen and (max-width: 420px) {
	.app .header-icon:not(.btn) {
		min-width: unset;
	}
}

@media only screen and (max-width: 576px) {
	.page-wrapper .page-header {
		padding: 0 0.5rem;
	}
	.page-wrapper .page-content {
		padding: 0.5rem;
	}
}

@media only screen and (max-width: 992px) {
	.mb-7, .my-7 {
		margin-bottom: 1.0rem !important;
	}
	.mb-8, .my-8 {
		margin-bottom: 1.5rem !important;
	}
	
	.page-wrapper .page-header {
		padding: 0 1.0rem;
	}
	.page-wrapper .page-content {
		padding: 1.0rem;
	}
}
