@font-face {
	font-family: "Inter-Light";  src: url("/jakarta.faces.resource/fonts/inter/Inter_24pt-Light.ttf.xhtml?ln=default");
}

@font-face {
	font-family: "Inter-Medium";  src: url("/jakarta.faces.resource/fonts/inter/Inter_24pt-Medium.ttf.xhtml?ln=default");
}

@font-face {
	font-family: "Inter-Regular";  src: url("/jakarta.faces.resource/fonts/inter/Inter_24pt-Regular.ttf.xhtml?ln=default");
}

@font-face {
	font-family: "Inter-SemiBold";  src: url("/jakarta.faces.resource/fonts/inter/Inter_24pt-SemiBold.ttf.xhtml?ln=default");
}

@font-face {
	font-family: "Inter-Bold";  src: url("/jakarta.faces.resource/fonts/inter/Inter_24pt-Bold.ttf.xhtml?ln=default");
}

.inter-light {
	font-family: 'Inter-Light', serif;
}

.inter-medium {
	font-family: 'Inter-Medium', serif;
}

.inter-regular {
	font-family: 'Inter-Regular', serif;
}

.inter-semibold {
	font-family: 'Inter-SemiBold', serif;
}

.inter-bold {
	font-family: 'Inter-Bold', serif;
}

body {
	margin: 0px;
	font-family: Inter-Regular;
}

body .ui-commandlink:hover, body .ui-link:hover {
	text-decoration: none !important;
}

body .ui-datatable .ui-datatable-data>tr>td {
	padding: .3rem .3rem !important;
	font-size: .8rem !important;
}

.card {
	background: #ffffff;
	padding: 20px;
	box-sizing: border-box;
	box-shadow: 0 10px 40px rgba(41, 50, 65, 0.06);
	-moz-border-radius: 24px;
	-webkit-border-radius: 24px;
	border-radius: 24px;
	margin-bottom: 2rem;
}

.card:last-child {
	margin-bottom: 0;
}

.card .card-header {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding-bottom: 16px;
}

.card .card-header h6 {
	margin-bottom: 2px;
}

.card .card-header .subtitle {
	font-weight: 600;
	color: rgba(41, 50, 65, 0.5);
}

.card .card-subtitle {
	color: rgba(41, 50, 65, 0.5);
	font-weight: 600;
	margin: -1rem 0 1rem 0;
}

.card.no-gutter {
	margin-bottom: 0;
}

.small-horizontal-line {
	height: 1px;
	background-color: #666;
}

@media screen and (max-width: 991px) {
	.main-page {
		padding-bottom: 40px;
	}
}

@media screen and (min-width: 992px) {
	.main-page {
		min-height: 800px;
	}
}

@media screen and (max-width: 991px) {
	.footer-logo {
		height: 60px;
		padding: 8px;
	}
}

@media screen and (min-width: 992px) {
	.footer-logo {
		height: 100px;
		padding: 12px;
	}
}

@media screen and (max-width: 991px) {
	.small-horizontal-line {
		width: 100px;
		margin: 12px 0;
	}
}

@media screen and (min-width: 992px) {
	.small-horizontal-line {
		width: 200px;
		margin: 20px 0;
	}
}

.horizontal-line {
	height: 2px;
	background-color: #666;
	width: 100%;
	margin: 20px 0;
}

.circle-icon {
	width: 36px;
	height: 36px;
	background-color: transparent;
	color: #333333;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	border: 1px solid black;
}

.circle-icon-blue {
	color: #406089;
	border: 1px solid #406089;
}

.site-title {
	color: #406089;
	text-transform: uppercase;
}

@media screen and (max-width: 991px) {
	.site-title {
		font-size: 24px;
	}
}
@media screen and (min-width: 992px) {
	.site-title {
		font-size: 32px;
	}
}

.header-title {
	color: #333;
	font-family: Inter-Bold, serif;
	font-size: 1.5rem !important;
}

.header-title:hover {
	color: #333;
}

.page-title {
	color: #406089;
	text-transform: uppercase;
}

@media screen and (max-width: 991px) {
	.page-title {
		font-size: 24px;
	}
}
@media screen and (min-width: 992px) {
	.page-title {
		font-size: 32px;
	}
}

.container-title {
	color: #406089;
}

@media screen and (max-width: 991px) {
	.container-title {
		font-size: 22px;
		padding-bottom: 20px;
		margin-bottom: 1rem !important;
	}
}
@media screen and (min-width: 992px) {
	.container-title {
		font-size: 24px;
		margin-bottom: 1.5rem !important;
	}
}

.container-subtitle {
	color: #406089;
}

@media screen and (max-width: 991px) {
	.container-subtitle {
		font-size: 18px;
		padding-bottom: 16px;
	}
}
@media screen and (min-width: 992px) {
	.container-subtitle {
		font-size: 20px;
	}
}

.container-intro {
	color: #333;
}

@media screen and (max-width: 991px) {
	.site-index {
		font-size: 18px;
	}
}
@media screen and (min-width: 992px) {
	.site-index {
		font-size: 32px;
	}
}

.site-important-text {
	font-family: Inter-Bold, serif;
	line-height: 1.25;
}
@media screen and (max-width: 991px) {
	.site-important-text {
		font-size: 18px;
	}
}
@media screen and (min-width: 992px) {
	.site-important-text {
		font-size: 30px;
	}
}

.site-text {
	font-family: Inter-Medium;
	line-height: 1.5;
}

@media screen and (max-width: 991px) {
	.site-text {
		font-size: 16px;
	}
}
@media screen and (min-width: 992px) {
	.site-text {
		font-size: 18px;
	}
}

.ui-button, button {
	background-color: #406089 !important;
	color: white !important;
	border: none !important;
	text-transform: uppercase !important;
}

.ui-button:hover, button:hover {
	background-color: #6080A9 !important;
}

.green-button.ui-button, .green-button .ui-button, .green-button.button {
	background-color: #689f38 !important;
}

.green-button.ui-button:hover, .green-button .ui-button:hover, .green-button.button:hover {
	background-color: #5e8f32 !important;
}

.orange-button.ui-button, .orange-button .ui-button, .orange-buttonbutton {
	background-color: #e66100 !important;
}

.orange-button.ui-button:hover, .orange-button .ui-button:hover, .orange-button.button:hover {
	background-color: #cf5700 !important;
}


.text-blue-susi {
	color: #6080A9 !important;
}

.custom-button {
	font-weight: bold !important;
	transition: background-color 0.3s ease;
	border: none !important;
	font-weight: bold !important;
}

@media screen and (max-width: 991px) {
	.custom-button {
		border-radius: 30px !important;
		padding: 10px 50px !important;
		font-size: 12px !important;
	}
}

@media screen and (min-width: 992px) {
	.custom-button {
		border-radius: 50px !important;
		padding: 20px 80px !important;
		font-size: 16px !important;
	}
}

.small-custom-button {
	font-weight: bold !important;
	transition: background-color 0.3s ease;
	border: none !important;
}
@media screen and (max-width: 991px) {
	.small-custom-button {
		border-radius: 50px !important;
		padding: 8px 16px !important;
		font-size: 12px !important;
	}
}
@media screen and (min-width: 992px) {
	.small-custom-button {
		border-radius: 50px !important;
		padding: 8px 16px !important;
		font-size: 12px !important;
	}
}


.small-custom-file-upload .ui-button {
	border-radius: 50px !important;
	padding: 8px 16px !important;
}

.small-custom-file-upload .ui-button.ui-button-text-icon-left .ui-button-text {
	font-size: 12px !important;
	font-weight: bold !important;
}

/* Reposicionamiento icon small custom button */
.small-custom-button.ui-button-text-icon-left .ui-icon {
	left: 1.5rem !important;
}
/* Reposicionamiento icon small custom button en file uploader*/
.small-custom-file-upload .ui-button.ui-button-text-icon-left .ui-icon {
	left: 1.5rem !important;
}

body .ui-button.button-download {
	background: #e66100 !important;
	border: 1px solid #e66100 !important;
}

.transparent-button {
	background-color: transparent !important; /* Color de fondo */
	color: black !important;             /* Color del texto */
	border: 1px solid black !important;
}

.black-button {
	background-color: black !important; /* Color de fondo */
	color: white !important;             /* Color del texto */
	border: 1px solid black !important;
}

.transparent-button:hover {
	background-color: #EEEEEE !important; /* Color de fondo */
}

.rounded-button {
	background-color: #000;      /* Color de fondo negro */
	color: #fff;                 /* Texto blanco */
	border: none;                /* Sin bordes adicionales */
	font-weight: bold;           /* Texto en negrita */
	cursor: pointer;             /* Cursor de mano al pasar */
	transition: background-color 0.3s ease; /* Efecto suave en hover */
}
@media screen and (max-width: 991px) {
	.rounded-button {
		border-radius: 50px; /* Bordes circulares */
		padding: 20px 50px; /* Espaciado interno */
		font-size: 14px; /* Tamaño de letra */
	}
}
@media screen and (min-width: 992px) {
	.rounded-button {
		border-radius: 50px; /* Bordes circulares */
		padding: 20px 50px; /* Espaciado interno */
		font-size: 14px; /* Tamaño de letra */
	}
}

.rounded-button:hover {
	background-color: #333;
}

label {
	font-family: Inter-Bold, serif;
	text-transform: uppercase;
}

.form-label {
	padding-top: .3rem !important;
	display: flex !important;
	flex-wrap: wrap !important;
	align-content: center !important;
	font-weight: 700 !important;
}

.form-value {
	padding-top: .3rem !important;
}

@media screen and (max-width: 991px) {
	.form-label {
		justify-content: flex-start !important;
		text-align: left !important;
	}
}

@media screen and (min-width: 992px) {
	.form-label {
		width: 100%;
		justify-content: flex-end !important;
		text-align: right !important;
	}
}

/* MENU */
.susi-menu {
	border: 0px !important;
	background-color: transparent !important;
}

.susi-menu > .ui-menu-list {
	display: flex;
	flex-direction: column;
}

.susi-menu > .ui-menu-list > .ui-menuitem {
	border-bottom: 1px solid #eeeeee !important;
}

/* HOVER COMMAND LINK */
.hover-command-link,
.hover-command-link img {
	opacity: 1;
	transition: opacity 0.3s ease !important;
}

.hover-command-link:hover,
.hover-command-link:hover img {
	opacity: 0.8 !important;
}

.pageFooter {
	background: #12497e;
	padding: 0px;
	margin-top: 12px;
}

.footerText {
	color: white;
	display: block;
}
