@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lekton:ital,wght@0,400;0,700;1,400&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto+Mono:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Fira+Mono:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;600;700;800&display=swap");

* {
	/*font-family: 'Inter';*/
	/*font-family: var(--bs-font-monospace);*/
	/*font-family: 'Lekton', sans-serif;*/
	/*font-family: 'Roboto Mono', monospace;*/
	/* font-family: 'Fira Mono', monospace; */
	font-family: "Noto Sans", sans-serif;
}

html,
body {
	height: 100%;

	font-size: 14px;
}

.text-primary {
	color: #032e66 !important;
}

a {
	color: #032e66;
	text-decoration: none;
}

a:hover {
	color: #032e66;
	opacity: 0.9;
}

p,
li {
	font-size: 1rem;

	color: #93acc2;
}

ul {
	list-style: none;

	padding: 0;
	margin: 0;
}

label {
	font-size: 0.85rem;
	/*font-weight: 600;*/

	color: #032e66;

	display: block;
	margin-bottom: 4px;
}

hr {
	background: #93acc2;
	margin: 0;
}

/* pattern */

.fw-600 {
	font-weight: 600;
}

.min-h-100vw {
	min-height: 100vh;
}

.mxh-40px {
	max-height: 40px;
}

.mxh-220px {
	max-height: 220px;
}

/* inputs */

input.form-control,
select.form-control {
	height: 3.21rem;

	font-size: 1rem;

	border: 1px solid #93acc2;

	border-radius: 8px;
}

.form-control:focus {
	box-shadow: none !important;
	outline: none !important;

	border-color: #008aff;
}

.form-control::placeholder {
	color: #93acc2;

	font-size: 1rem;
}

.form-switch {
	display: flex;
	align-items: center;
}

.form-switch label {
	margin: 0;
	margin-left: 8px;
	margin-bottom: -2px;

	line-height: 1;
}

.form-switch .form-check-input:checked {
	background-color: #032e66;
	box-shadow: none !important;
	border-color: #032e66;
}

/* buttons */

.btn {
	padding: 0.71rem 1.71rem;

	border-radius: 8px;

	font-size: 1rem;
	font-weight: 600;

	display: inline-flex;
	justify-content: center;
	align-items: center;

	box-shadow: none !important;
	background: #f3f6fb;
	border-bottom: 2px solid #d4d9e0
}

.btn ion-icon {
	font-size: 1.28rem;
	min-width: 1.28rem;
	min-height: 1.5rem;
}

.btn ion-icon[size="large"] {
	max-width: 1.85rem;
}

.btn:hover {
	opacity: 0.9;
}

.btn-primary,
.btn-primary:hover {
	background: #008aff;
	border-color: #008aff;
	color: #ffffff;
	border-bottom: 2px solid #1879cb;
}

.btn-light-blue,
.btn-light-blue:hover {
	background: #0088ff1a;
	border-color: transparent;
	color: #032e66;
	border-bottom: 2px solid #d3dce9;
}

.btn-medium-gray,
.btn-medium-gray:hover {
	background: #93acc233;
	border-color: transparent;
	color: #032e66;
}

.btn-medium-blue,
.btn-medium-blue:hover {
	background: #0088ff33;
	border-color: transparent;
	color: #032e66;
}

.btn-primary-outline {
	background: transparent;
	border-color: #008aff;
	color: #008aff;
}

.btn-primary-outline:hover {
	background: #008aff;
	border-color: #008aff;
	color: #ffffff;
}

.btn-secondary,
.btn-secondary:hover {
	background: #032e66;
	border-color: #032e66;
	color: #ffffff;
	border-bottom: 2px solid #000f23;
}

.btn-gray,
.btn-gray:hover {
	background: #93acc2;
	border-color: #93acc2;
	color: #ffffff;
	border-bottom: 2px solid #7d8fa2;
}

.btn-simple,
.btn-simple:hover {
	background: #93acc233;
	border-color: transparent;
	color: #032e66;
	border-bottom: 2px solid #e2e5e9;
}

.btn-success,
.btn-success:hover {
	background: #25d365;
	border-color: #25d365;
	color: #ffffff;
	    border-bottom: 2px solid #1bb052;
}

.btn-success.disabled,
.btn-success:disabled {
	color: #fff;
	background-color: #25d365;
	border-color: #25d365;
	opacity: 0.6;
}

.btn-warning,
.btn-warning:hover {
	background: #ffc107;
	border-color: #ffc107;
	color: #ffffff;
}

.btn-danger,
.btn-danger:hover {
	background: #d73e50;
	border-color: #d73e50;
	color: #ffffff;
	border-bottom: 2px solid #9b2835;
}

.btn-info,
.btn-info:hover {
	background: #147cd3;
	border-color: #147cd3;
	color: #ffffff;
}

.btn-orange,
.btn-orange:hover {
	background: hsl(32deg 100% 50%);
	border-color: hsl(32deg 100% 50%);
	color: #ffffff;
	border-bottom: 2px solid #cb720d;
}

/* alerts */

div.alert {
	width: 100%;

	display: flex;
	align-items: center;
	justify-content: space-between;

	padding: 1.71rem 1.71rem 1.71rem 2.78rem;

	border-radius: 8px;

	position: relative;

	overflow: hidden;

	margin-bottom: 0;
}

div.alert > div {
	display: flex;
}

div.alert::before {
	content: "";

	width: 10px;
	height: 100%;

	position: absolute;
	top: 0;
	left: 0;
}

div.alert ion-icon {
	min-width: 2.28rem;
	font-size: 2.28rem;

	margin-right: 24px;
	margin-top: 4px;
}

div.alert h4 {
	font-size: 1.14rem;
	font-weight: 600;

	margin-bottom: 8px;
}

div.alert p {
	margin-bottom: 0;

	line-height: 1;

	font-weight: 400;
}

/* success */

div.alert.alert-success {
	background: #25d36533;
	border-color: transparent;
}

div.alert.alert-success ion-icon,
div.alert.alert-success h4,
div.alert.alert-success p {
	color: #25d365;
	filter: brightness(0.7);
}

div.alert.alert-success::before {
	background: #25d365;
}

/* warning */

div.alert.alert-warning {
	background: #ffc10733;
	border-color: transparent;
}

div.alert.alert-warning ion-icon,
div.alert.alert-warning h4,
div.alert.alert-warning p {
	color: #ffc107;
	filter: brightness(0.7);
}

div.alert.alert-warning::before {
	background: #ffc107;
}

/* danger */

div.alert.alert-danger {
	background: #d73e5033;
	border-color: transparent;
}

div.alert.alert-danger ion-icon,
div.alert.alert-danger h4,
div.alert.alert-danger p {
	color: #d73e50;
	filter: brightness(0.7);
}

div.alert.alert-danger::before {
	background: #d73e50;
}

/* info */

div.alert.alert-info {
	background: #147cd333;
	border-color: transparent;
}

div.alert.alert-info ion-icon,
div.alert.alert-info h4,
div.alert.alert-info p {
	color: #147cd3;
	filter: brightness(0.7);
}

div.alert.alert-info::before {
	background: #147cd3;
}

/* table */

table.table {
	width: 100% !important;
}

table.table thead th {
	text-transform: uppercase;
	font-weight: 500;

	padding: 8px 0;

	color: #93acc2;
}

table.table tbody td {
	padding: 1.14rem 1.14rem 1.14rem 0;
}

table.table tbody td:last-child {
	padding: 1.14rem 0 1.14rem 0;
}

table.table thead th,
table.table tbody td {
	vertical-align: middle;
	font-size: 1rem;
}

table.table tbody td .btn ion-icon {
	font-size: 1.42rem;
	min-width: 1.42rem;
}

table.table tbody td .btn.own {
	padding: 10px;
	width: 43px;
}

main table.table > :not(:first-child) {
	border-top: 1px solid #93acc2;
}

table.table .path .document {
	display: flex;
	align-items: flex-end;
}

table.table .path .document ion-icon {
	color: #008aff;

	margin-right: 8px;

	font-size: 1.28rem;
	min-width: 1.28rem;
}

table.table .path .document a {
	line-height: 1;
	font-size: 1rem;
	font-weight: 500;
	color: #032e66;
	max-width: 100%;
	word-break: break-word;
}

div#DataTables_Table_0_info {
	color: #93acc2;
}

table.table .path .document span.more-files {
	margin-left: 0.65rem;

	display: flex;
	justify-content: center;
	align-items: center;

	min-width: 1.22rem;
	min-height: 1.32rem;

	border-radius: 0.3rem;

	border: 2px solid #008aff;
	background: #ffffff;

	position: relative;
}

table.table .path .document span.more-files span {
	font-size: 0.65rem;
	font-weight: 700;

	color: #008aff;
}

table.table .path .document span.more-files::before {
	content: "";

	position: absolute;
	top: 1px;
	left: -5px;

	min-width: 1.22rem;
	min-height: 1.32rem;

	border-radius: 0.3rem;

	border: 2px solid #008aff;

	z-index: -1;
}

/* table.table .path .document span.more-files ion-icon {
    transform: rotateX(180deg);

    color: #93acc2;

    font-size: 1.28rem;
}

table.table .path .document span.more-files span {
    position: absolute;
    top: calc(50% - 0.07rem);
    left: calc(50% - 0.2rem);
    transform: translate(-50%, -50%);
    font-size: 0.53rem;
    font-weight: 900;
    color: #607d8b;
} */

table.table .path span.down {
	position: relative;

	width: 18px;
	height: 30px;

	margin-right: 4px;
	margin-top: 2px;
}

table.table .path span.down::before {
	content: "";

	width: 2px;
	height: 17px;

	background: #93acc2;

	position: absolute;
	top: 0;
	left: 50%;

	transform: translateX(-50%);
}

table.table .path span.down::after {
	content: "";

	width: 10px;
	height: 2px;

	background: #93acc2;

	position: absolute;
	top: 17px;
	left: 13px;

	transform: translate(-50%, 0);
}

table.table .path .folder {
	display: flex;
	align-items: center;

	margin-top: 4px;
}

table.table .path .folder ion-icon {
	color: #ffc107;

	margin-right: 8px;

	font-size: 1.28rem;
	min-width: 1.28rem;
}

table.table .path .folder span {
	line-height: 1;
	font-size: 1rem;
	font-weight: 400;
	color: #032e66;
	margin-right: 8px;
	display: block;
	text-decoration: underline;
	cursor: pointer;
}

table.table .path .folder button {
	padding: 2px 8px;

	font-size: 0.57rem;
	font-weight: 500;
	letter-spacing: 1px;

	color: #ffffff;

	background: #008aff;

	border: none;

	border-radius: 4px;
}

table.table .assinados .ul .li {
	display: flex;
	align-items: center;

	margin-bottom: 8px;

	font-weight: 500;

	color: #032e66;
}

table.table .assinados .ul .li:last-child {
	margin-bottom: 0;
}

table.table .assinados .ul .li ion-icon {
	margin-right: 10px;

	color: #93acc2;

	font-size: 1.42rem;
	min-width: 1.42rem;
}

table.table .assinados .ul .li.active ion-icon {
	margin-right: 10px;

	color: #25d366;
}

table.table .status {
	display: inline-flex;
	align-items: center;

	padding: 4px 16px;

	border-radius: 5px;
}

table.table .status.pendente {
	background: #ffc107;
	color: #ffffff;
}

table.table .status.revisar {
	background: #008aff;
	color: #ffffff;
}

table.table .status.assinado {
	background: #25d366;
	color: #ffffff;
}

table.table .autenticacoes h6 {
	color: #032e66;

	font-weight: 600;

	margin-bottom: 0;
}

table.table .autenticacoes p {
	color: #032e66;
}

table.table .user h4 {
	font-size: 1.14rem;
	font-weight: 600;

	color: #032e66;

	margin-bottom: 4px;
}

table.table .user h6 {
	font-size: 1rem;

	color: #93acc2;
	margin-bottom: 0;
}

/* filter */

aside.filter {
	width: 348px;
	height: 100%;
	min-height: 100%;

	padding: 24px;

	position: fixed;
	top: 0;
	right: -360px;
	z-index: 9;

	transition: 0.4s;

	background: #ffffff;

	box-shadow: 0 0 24px -8px #0088ff63;
}

aside.filter.open {
	right: 0;
}

aside.filter button.close {
	position: absolute;
	top: 24px;
	right: 24px;

	background: transparent;
	border: none;
	color: #93acc2;

	font-size: 1.71rem;
}

aside.filter h4 {
	font-size: 1.28rem;
	font-weight: 600;

	color: #032e66;
}

div.modal div.modal-header {
	align-items: flex-start;
}

div.modal div.modal-header h4 {
	font-weight: 500;

	color: #032e66;

	font-size: 1.5rem;
	margin-bottom: 0px;
}

div.modal div.modal-header p {
	margin-bottom: 0;
	padding-right: 16px;

	font-size: 0.85rem;
}

div.modal div.modal-header button.close {
	height: 24px;
	padding: 0;

	font-size: 1.71rem;

	color: #93acc2;

	border: none;
	background: transparent;
}

.modal-content {
	border-color: #ffffff;
}

div.modal div.modal-body .alert p {
	font-size: 1rem;
	line-height: 1.4;
}

.modal-dialog {
	max-width: 600px;
}

.form-check {
	display: flex;
	align-items: center;
}

.form-check label {
	margin: 0;
	display: flex;
	margin-bottom: -3px;
}

.form-check-input[type="checkbox"] {
	margin-right: 8px;
	height: 20px;
	width: 20px;
}

div.modal div.modal-body h6 {
	font-size: 1rem;
	/* font-weight: 700; */

	margin-bottom: 0;

	/* color: #032E66; */
}

div.modal div.modal-body table.table tr:last-child td {
	border-bottom: 0;
}

div.modal div.modal-body .folders {
	margin-bottom: 24px;
}

div.modal div.modal-body .folders div.item {
	padding: 16px;

	border-radius: 8px;

	background: transparent;

	text-align: center;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;

	cursor: pointer;
}

div.modal div.modal-body .folders div.item ion-icon {
	font-size: 4.57rem;
	min-width: 4.57rem;

	color: #ffc107;
}

div.modal div.modal-body .folders div.item ion-icon:first-child {
	display: none;
}

div.modal div.modal-body .folders div.item.selected,
div.modal div.modal-body .folders div.item:hover {
	padding: 16px;

	border-radius: 8px;

	background: #93acc214;
}

div.modal div.modal-body .folders div.item.selected {
	cursor: unset;
}

div.modal div.modal-body .folders div.item.selected ion-icon:first-child {
	display: block;

	color: #008aff;

	font-size: 1.42rem;
	min-width: 1.42rem;

	margin-bottom: -20px;
	margin-right: -60px;

	position: relative;
	z-index: 1;
}

.modal-footer {
	border-top: none !important;
	padding-top: 0;
}

td .title-header {
	display: none;
}

table.table .autenticacoes p {
	margin-bottom: 0;
}

span.destaque {
	padding: 0 4px;

	background: #f3f6fb;
}

table.table th[aria-label*="ARQUIVOS"] {
	width: 30% !important;
}

.form-switch .form-check-input[type="checkbox"] {
	min-width: 40px;
	margin-right: 16px;
}

@media (min-width: 991px) {
	main div.counters-dashboard div.col-lg {
		max-width: calc(33.33333333%);
	}
}

@media (max-width: 1400px) {
	.btn {
		font-size: 1.2rem;
	}

	label {
		font-size: 1rem;
	}
}

@media (max-width: 991px) {
	.modal-body::-webkit-scrollbar-track {
		background-color: #f4f4f4;
	}
	.modal-body::-webkit-scrollbar {
		width: 6px;
		background: #f4f4f4;
	}
	.modal-body::-webkit-scrollbar-thumb {
		background: #dad7d7;
	}

	div.alert {
		flex-direction: column;
		align-items: flex-start;
	}

	div.alert .btn {
		margin-top: 16px;
		/* width: unset; */
	}

	td .title-header {
		display: none;

		position: absolute;
		top: 0;
		left: 0;

		padding: 4px 8px;

		width: 100%;

		background: hsla(208, 28%, 67%, 0.2);
		color: #032e66;

		font-weight: 600;
		font-size: 0.85rem;
		text-transform: uppercase;
	}

	thead {
		display: none;
	}

	tr {
		display: flex;
		flex-direction: column;
		position: relative;
	}

	table.table tbody td {
		padding: calc(1.14rem) 0 1.14rem !important;

		position: relative;
	}

	table.table tbody td {
		position: unset;
	}

	table.table tbody td .excluir_s {
		position: absolute;
		top: 2.28rem;
		right: 0;
	}

	table.table tbody td:last-child {
		padding-bottom: calc(1.14rem + 1.14rem) !important;
	}

	table.table tbody td:first-child {
		padding-top: calc(1.14rem + 1.14rem) !important;
	}

	div.modal .btn {
		width: unset;
	}

	div.modal tr {
		display: table-row;
		margin-bottom: 24px;
	}

	div.modal div.modal-body table.table tr td {
		padding: 24px 0 !important;
	}

	table.table .autenticacoes-item {
		flex-wrap: wrap;
	}

	table.table .autenticacoes-item .item {
		margin-bottom: 8px !important;
	}

	table.table tbody td {
		border: none;
	}

	table.table tbody td:last-child {
		border-bottom: 1px solid #0088ff33;
	}

	table.table .path .document {
		padding-right: 4.28rem;
	}

	div#DataTables_Table_0_info {
		display: none;
	}

	div#DataTables_Table_0_paginate {
		justify-content: center;
	}
}

@media (max-width: 768px) {
	.btn {
		width: 100%;
	}
}

@media (max-width: 576px) {
	main {
		padding: 0 0 48px;
	}

	div.container-fluid {
		padding: 0 16px;
	}

	div.container {
		padding: 0 16px;
	}

	main div.container-fluid {
		padding: 0 16px !important;
	}

	main div.container {
		padding: 0 16px !important;
	}

	div.modal .adicionar {
		padding: 10px;

		display: flex;
		align-items: center;
		justify-content: center;
	}

	div.modal .adicionar span {
		display: none;
	}

	.pagination {
		display: flex;
		padding-left: 0;
		list-style: none;
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 1400px) {
	html,
	body {
		font-size: 12px;
	}
}

@media (max-width: 1300px) {
	html,
	body {
		font-size: 11px;
	}
}

div#DataTables_Table_0_paginate {
	display: flex;
	justify-content: flex-end;
}

.modal-body {
	padding: 2rem;
}

.modal-header {
	padding: 1.5rem;
}



/* loader */

span.loader {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;

	padding: 2rem;
}

span.loader::before {
	content: "";
	width: 48px;
	height: 48px;
	border: 5px solid #008aff3b;
	border-bottom-color: #008aff;
	border-radius: 50%;
	display: inline-block;
	box-sizing: border-box;
	animation: rotation 1s linear infinite;
}

@keyframes rotation {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}