/* Estilos específicos de la aplicación */
button.ui-button-icon-only {
    width: 2em;
    heigth: 2em
}

.percent100 .ui-autocomplete-multiple-container {
    width: 100%;
    box-sizing: border-box;
}
/* datatable con los bordes redondeados*/
.ui-datatable.ui-corner-all table {
    border-collapse: separate;
    *border-collapse: collapse;
    border-spacing: 0;
}

.ui-datatable.ui-corner-all table tr:first-child th:first-child {
    -moz-border-radius: 4px 0 0 0;
    -webkit-border-radius: 4px 0 0 0;
    border-radius: 4px 0 0 0;
}

.ui-datatable.ui-corner-all table tr:first-child th:last-child {
    -moz-border-radius: 0 4px 0 0;
    -webkit-border-radius: 0 4px 0 0;
    border-radius: 0 4px 0 0;
}

.ui-datatable.ui-corner-all table tr:first-child th:only-child {
    -moz-border-radius: 4px 4px 0 0;
    -webkit-border-radius: 4px 4px 0 0;
    border-radius: 4px 4px 0 0;
}

.ui-datatable.ui-corner-all table tbody td {
    border-top: 0;
    border-top: inherit;
}

.ui-datatable.ui-corner-all table tr:last-child td:first-child {
    -moz-border-radius: 0 0 0 4px;
    -webkit-border-radius: 0 0 0 4px;
    border-radius: 0 0 0 4px;
}

.ui-datatable.ui-corner-all table tr:last-child td:last-child {
    -moz-border-radius: 0 0 4px 0;
    -webkit-border-radius: 0 0 4px 0;
    border-radius: 0 0 4px 0;
}

.ui-datatable.ui-corner-all table tr:last-child td:only-child {
    -moz-border-radius: 0 0 4px 4px;
    -webkit-border-radius: 0 0 4px 4px;
    border-radius: 0 0 4px 4px;
}

.panelDataTable .ui-panel-content {
    padding: 3px 3px 3px 3px;
}

.tableNoBorder>tbody>tr>td {
    border-style: none !important;
    padding: 0 0 0 0;
}

.listNoBorder>table>tbody>tr>td {
    border-style: none !important;
    padding: 0 0 0 0;
}

.datatable-header-buttons-filter {
    width: 100%;
    text-align: right;
    height: 22px;
    line-height: 22px;
}

/* SIGA */

.block {
	display: block;	
}

.hidden {
	display: none;	
}

.no-visible {
	visibility: hidden;	
}

.left, .left .ui-inputfield {
	text-align: left;
}

.right, .right .ui-inputfield {
	text-align: right;
}

.center, .center .ui-inputfield {
	text-align: center;
}

.justify, .justify .ui-inputfield {
	text-align: justify;
}

.negrita {
	font-weight: bold;
}

.cursiva {
	font-style: italic;
}

.monospace {
	font-family: monospace;
}

.mayusculas {
	text-transform: uppercase;
}

.minusculas {
	text-transform: lowercase;
}

.enlace, .enlace:visited, .enlace:focus {
	text-decoration: none;
	outline: 0;
}

.enlace:hover {
	text-decoration: underline;
}

.disabled, .disabled .ui-inputfield, .disabled.ui-selectoneradio label, .disabled .ui-autocomplete-input {
	opacity: 1 !important;
}

.disabled.ui-inputfield, .disabled input, .disabled.ui-selectonemenu label, .disabled.ui-selectonemenu .ui-selectonemenu-trigger {
	background-color: #eee !important;	
}

.disabled.ui-autocomplete-multiple input {
	background-color: #fff !important;	
}

.blue {
	color: blue;
}

.gray {
	color: gray;
}

.green {
	color: green;
}

.orange {
	color: orange;
}

.red {
	color: red;
}

.bg-lightgreen {
	background-color: #d5f5d1;
}

.bg-lightred {
	background-color: #ffdada;
}

.bg-lightyellow {
	background-color: #fffdbd !important;
}

.bg-white {
	background-color: white;
}

.arial {
	font-family: Arial, Verdana, sans-serif;
}

.w25px {
	width: 25px;
}

.w100x {
	width: 100%;
}

.fl {
	float: left;
}

.fr {
	float: right;
}

/* Ajustada la visualizacion de los campos erroneos */

.ui-inputfield.ui-state-error, .ui-selectonemenu.ui-state-error, .ui-radiobutton-box.ui-state-error, .ui-chkbox-box.ui-state-error {
	border: 1px solid #ef5350;
}

.ui-inputfield.ui-state-error, .ui-selectonemenu.ui-state-error .ui-selectonemenu-label, .ui-radiobutton-box.ui-state-error, .ui-chkbox-box.ui-state-error {
	background-color: #ffdada;
}

.ui-inputnumber.ui-state-error {
	border: none;
}

/* Ajustada la visualizacion de los campos obligatorios */

.ui-outputlabel .ui-outputlabel-rfi {
	display: none;
	margin-left: 1px;
	color: red;
}

.ui-inputfield[data-p-required="true"] {
	border-left: 3px solid #cd0808;
}

.ui-selectonemenu.ui-selectonemenu-required {
	border-left: 3px solid #cd0808;
}

/* Estilo para los botones */

.ui-button-big, .ui-button-big.ui-menubutton .ui-button {
	height: 35px;
}

/* Estilo para los menus */

.ui-menu {
	width: 215px;
}

.ui-menu-475 {
	width: 475px;
}

.ui-menu-495 {
	width: 495px;
}

.ui-menu-630 {
	width: 630px;
}

/* Estilo para las tablas */

.ui-datatable .ui-datatable-data tr.ui-widget-content td, .ui-datatable tfoot tr td {
	text-overflow: ellipsis;
}

.ui-datatable .ui-datatable-scrollable-body {
	overflow-x: hidden;
	outline: 0;
	border: none;
}

.ui-datatable tr.ui-state-highlight {
	background-color: #D0E0E8 !important;
}

/* Estilo para las cabeceras de las tablas */

.ui-datatable th.ui-header-border-top {
	border-top: 1px solid #888 !important;
}

.ui-datatable th.ui-header-border-bottom {
	border-bottom: 1px solid #888 !important;
}

.ui-datatable th.ui-header-border-left {
	border-left: 1px solid #888 !important;
}

.ui-datatable th.ui-header-border-right {
	border-right: 1px solid #888 !important;
}

/* Estilo para las subtablas */

.ui-datatable .ui-expanded-row-content .ui-datatable {
	width: 90%;
	margin: 10px auto;
}

/* Estilo para los panelgrid */

.ui-panelgrid .ui-grid-col-no-padding {
	padding: 0 !important;
}

/* Estilo para las tablas (dentro de panelgrid con el estilo ui-panelgrid-blank) */

.ui-panelgrid.ui-panelgrid-blank .ui-datatable .ui-datatable-data tr.ui-widget-content {
	border-width: 1px;
	border-style: solid;
	border-color: #ddd;
}

.ui-panelgrid.ui-panelgrid-blank .ui-datatable tr.ui-datatable-odd {
	background-color: rgba(241, 241, 241, 0.69);
	background-image: none;
}

/* Estilo para los datagrid */

.ui-datagrid-no-border .ui-datagrid-content {
	border: none;
}

.ui-datagrid-no-padding > .ui-datagrid-content > .ui-g > .ui-datagrid-column {
	padding: 0;
}

/* Estilos para los picklist */

.ui-picklist .ui-picklist-list, .ui-picklist .ui-picklist-buttons {
	height: 155px;
}

.picklist-small.ui-picklist .ui-picklist-list, .picklist-small.ui-picklist .ui-picklist-buttons {
	height: 100px;
}

@media (min-width: 641px) {
	.ui-picklist.ui-picklist-vertical .ui-picklist-buttons button {
		width: 35px;
	}
}

.ui-picklist-odd-even li {
	margin: 0 !important;
	border-bottom: 1px solid #ddd !important;
	border-radius: 0;
}
.ui-picklist-odd-even li:nth-child(odd) {
	background-color: rgba(241, 241, 241, 0.69);
}
.ui-picklist-odd-even li:nth-child(even) {
    
}

.ui-picklist-estadisticas .ui-picklist-list { 
	height: 233px;
}

.ui-picklist-estadisticas .ui-picklist-buttons { 
	height: 168px;
}

/* Estilo para los paneles */

@media (max-width: 640px) {
	.ui-panel-no-padding-mobile .ui-panel-content {
		padding: 0;
	}
}

/* DataList */
.ui-datalist-padding0 .ui-datalist-content {
	border: none;
}

.ui-datalist-padding0 ul{
	padding-left: 0;
}

/* Estilo para los iconos de la barra de titulo en los paneles */

.ui-panel .ui-panel-titlebar-icon, .ui-panel .ui-panel-actions {
	float: left;
	margin-right: .2em;
}

.ui-panel-titlebar-icon {
	margin-top: 0 !important;
}

.ui-panel-titlebar-icon .fa {
	padding: 0px 2px;
}

.ui-panel-titlebar-icon .ui-icon {
	width: 14px;
	height: 13px;
}

.ui-panel-titlebar-icon .ui-icon-minusthick {
	background-position: 0px -17px;
}

.ui-panel-titlebar-icon .ui-icon-plusthick {
	background-position: -65px -16px;
}

/* Estilo para el fieldset */

.ui-fieldset-legend {
	padding: 3px 5px 0px 3px !important;
}
.ui-fieldset-legend .ui-icon-minusthick {
	background-position: 0 -17px;
}
.ui-fieldset-legend .ui-icon-plusthick {
	background-position: -65px -16px;
}
.ui-fieldset-toggler {
	top: -1px;
	padding-right: 0px !important;
}

/* Estilo para el fieldset sin borde */

.ui-fieldset-no-border {
	margin: 0 !important;
	padding: 0;
	border: none;
}

.ui-fieldset-no-border .ui-fieldset-legend {
	display: none;
}

/* Estilo para los label */
.hiddenLabel .label {
	display: none;
}

/* Estilo para los inputfield */

.ui-inputfield-panel {
	position: relative;
}

.ui-inputfield-icon {
	position: relative;
	display: initial;
}

.ui-inputfield-icon:before {
	position: absolute;
	right: 4px;
	top: 0px;
}

/* Estilo para los inputtextarea */

.ui-inputtextarea-portal {
	font-size: 14px !important;
	display: block;
	max-width: 600px !important;
	white-space: nowrap;
	overflow: auto !important;
}

/* Estilo para los botones de traduccion de inputfield inputtextarea y ckeditor */

.ui-inputfield-translate-button {
	position: absolute;
	right: 0;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
}

.ui-inputtextarea-translate-button {
	border-bottom-left-radius: 10px;
}

.ui-ckeditor-translate-button {
	top: 0;
	right: -2px;
	border-bottom-left-radius: 10px;
}

/* Estilo para los autocomplete */

.ui-autocomplete-panel .ui-autocomplete-items .ui-state-highlight {
	background-size: auto;
}

/* Estilo para los autocomplete con columnas */

.ui-autocomplete-panel .ui-autocomplete-table tr, .ui-autocomplete-panel .ui-autocomplete-table th, .ui-autocomplete-panel .ui-autocomplete-table td {
	border: none;
}

.ui-autocomplete-panel .ui-autocomplete-table tr.ui-state-highlight {
	background-image: none;
	border: 1px solid;
	border-color: #ddd !important;
}

/* Estilo para los autocomplete multiples */

.ui-autocomplete-multiple input {
	padding: 0;
}

/* Estilo para los combos */

.ui-selectonemenu-label {
	padding: 3px;
}

.ui-selectonemenu-trigger {
	/*border: 1px solid #1f89ce !important;
	background-color: #2399e5 !important;*/
	width: 27px !important;
}

.ui-selectonemenu-trigger .ui-icon {	
	/*background-image: url("../javax.faces.resource/images/ui-icons_ffffff_256x240.png.jsf?ln=primefaces-omega");*/
}

/* Estilo para el filtro de los combos */

.ui-selectonemenu-panel .ui-selectonemenu-filter-container {
	width: 100%;
	box-sizing: border-box;
}
.ui-selectonemenu-panel .ui-selectonemenu-filter-container .ui-inputfield {
	width: 100%;
	box-sizing: border-box;
}

.ui-selectonemenu-panel .ui-selectonemenu-filter-container .ui-icon-search {
	top: 8px !important;
	right: 7px;
}

/* Estilo para los combos con columnas */

.ui-selectonemenu-panel .ui-selectonemenu-table tr, .ui-selectonemenu-panel .ui-selectonemenu-table th, .ui-selectonemenu-panel .ui-selectonemenu-table td {
	border: none;
}

/*.ui-selectonemenu-panel .ui-selectonemenu-table tr.ui-state-highlight {
	background-color: #D0E0E8;
	background-image: none;
	border: 1px solid;
	border-color: #ddd !important;
}*/

/* Estilo para el checkbox */

.ui-chkbox .ui-chkbox-label {
	margin: 3px 0 0 8px;
}

/* Estilo para el selectoneradio */

.ui-selectoneradio {
	position: relative;
	top: 2px;
}

/* Estilo para el selectoneradio responsive */

@media (min-width: 641px) {
	.ui-selectoneradio.ui-grid-responsive .ui-g-12 {
		width: unset;
	}
}
@media (max-width: 640px) {
 	/* Esto es necesario porque si el numero de radios es por ejemplo 5, primefaces no le asigna el estilo ui-g-12 */
	.ui-selectoneradio.ui-grid-responsive .ui-g > div {
		width: 100%;
		padding: .5em;
	}
}

/* Necesario en la vesión 6.2 de primefaces para que el texto del radio no se ponga debajo del radio cuando es largo */
.selectoneradio_patch td {
	display: flex;
    align-items: center;
    /*text-align: justify;*/
}

/* En IE 11 al definir el display a flex no corta el texto si es muy largo. */
.selectoneradio_patch {
	table-layout: fixed;
	width: 100%;
}

/* Estilo para el fileUpload */

.ui-fileupload-info {
	font-family: cursive;
	border: 5px dashed lightgreen;
	padding: 88px 0px;
	display: block;
}

.ui-fileupload-info:hover {
	background: repeating-linear-gradient(45deg, #fff, #fff 10px, #eee 10px, #eee 20px);
}

.ui-fileupload-remove {
	position: absolute;
	top: 65px;
	right: 30px;
	color: black;
}

.ui-fileupload-remove:hover {
	opacity: 0.7;
}

/* Estilos para el ckeditor */

.cke_wysiwyg_div {
	padding: 15px 15px !important;
	font-family: Tahoma;
	font-size: 14px;
}

.cke_resizer {
	display: none;
}

/* Estilos para el calendario de festivos/vacaciones (ui-holidays) */

.ui-holidays .ui-selectmanybutton .ui-button {
	width: 14.28%;
}

@media (max-width: 640px) {
	.ui-holidays .ui-selectmanybutton .ui-button {
		width: 25%;
	}
}

.ui-holidays .ui-datepicker-prev, .ui-holidays  .ui-datepicker-next, .ui-holidays .ui-datepicker-year {
	display:none
}

.ui-holidays .ui-datepicker-group {
	width: 25%;
	float: left;
	padding: 10px;
	box-sizing: border-box;
	border: none;
}

.ui-holidays-1 .ui-datepicker-group {
	width: 100%;
}

.ui-holidays-2 .ui-datepicker-group {
	width: 50%;
}

.ui-holidays-3 .ui-datepicker-group {
	width: 33.33%;
}

.ui-holidays-4 .ui-datepicker-group {
	width: 25%;
}

.ui-holidays-6 .ui-datepicker-group {
	width: 16.66%;
}

.ui-holidays-12 .ui-datepicker-group {
	width: 8.33%;
}

.ui-datepicker .ui-datepicker-header {
	border: 1px solid #a8a8a8;
}

.ui-holidays .ui-datepicker td {
    padding: 0;
}

.ui-holidays .ui-datepicker td a, .ui-holidays .ui-datepicker td span {
	line-height: 20px;
	padding: 0;
}

@media (max-width: 640px) {
	.ui-holidays .ui-datepicker-group {
		width: 100%;
	}
}

.ui-holidays .ui-datepicker td a.ui-state-default {
	background: lightgreen !important;
	color: black !important;
	text-shadow: none !important;
}

.ui-holidays .ui-datepicker td a.ui-state-active {
	background: #ff5454 !important;
	color: white !important;
}

/*.ui-holidays .ui-datepicker td .ui-state-disabled {
	background: #ff5454;
	color: white;
}*/

/* Estilo dialogo de confirmacion */

.ui-confirm-dialog .ui-dialog-content {
	display: flex;
	align-items: center;
}

.ui-confirm-dialog .ui-confirm-dialog-severity {
	height: auto;
	width: auto;
	padding: 5px 10px;
	font-size: 40px;
	/*color: #1f89ce;*/
}

.ui-confirm-dialog .ui-dialog-buttonpane {
	padding: 0;
}

.ui-confirm-dialog .ui-dialog-buttonpane .ui-panelgrid {
	margin: 10px 5px;
}

.ui-confirm-dialog .ui-dialog-buttonpane button {
	margin: 0;
}

/* Estilo boton junto a campo */

.ui-field-button {
	width: 25px !important;
	height: 22px !important;
	margin: 0;
}

.ui-field-button .ui-icon {
	font-size: 15px;
	margin-top: -8px !important;
	/*color: #3b667c;*/
}

/* Estilo para el detalle de los errores (se usa en las llamadas a los servicios web) */

.ui-error-detail {
	font-size: 12px;
	color: #b94a48;
	display: block;
	margin: 5px 0 0 0px;
}

/* Estilos para ocultar el contacto en la pagina de acceso denegado (403) */

.aywebfwk-error-contacto {
	display: none;
}

/* Estilos para la cabera en version movil */

@media (max-width: 640px) {
	#headerWrapper{
		position: absolute;
	}
	.header-app {
		text-align: left;
	}
	#environtmentFlag {
		position: absolute;
		right: 0;
		z-index: 1001;
		padding: 4px 8px;
		margin: 0 15px;
	}
}

/* Estilos para el Portal */

.portal-header {
	margin-top: 10px;
}

.portal-header .portal-title {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
}

.portal-header .portal-language {
	text-align: center;
	margin: 5px;
}

@media (min-width: 641px) {
	.portal-header {
		position: absolute;
		background: none;
		border: none;
	}
	.portal-header .portal-title {
		position: fixed;
		top: 10px;
		left: 0;
		width: 100%;
		z-index: 1001;
	}
	.portal-header .portal-language {
		position: fixed;
		top: 20px;
		right: 10px;
		z-index: 1002;
	}
	.portal-header .portal-session {
		position: fixed;
		top: 10px;
		right: 10px;
		z-index: 1002;
	}
}

/* Panel de acciones del modelo */

.actions .ui-button {
	min-height: 2em !important;
}

/* Color amarillo en botones */

.ui-button, button.ui-button.ui-state-default, .ui-button.ui-state-default {
	border-color: #ffc73f;
	color: #000;
	background-color: #ffc73f;
}

button.ui-button.ui-state-hover, .ui-button.ui-state-hover, button.ui-button.ui-state-focus, .ui-button.ui-state-focus {
	background-color: rgba(0, 0, 0, 0.8);
	color: #fff;
	transition: all 0.5s ease;
	border-color: #ffc73f;
}

/* Estilos para el formulario de autoliquidacion */

.autoliquidacion-panel {
	margin: 10px 0;
}

/* Estilos para el panelgrid de la tarifa tabla */

.tarifa-tabla .ui-panelgrid-cell {
	padding: 0;
}

@media (max-width: 640px) {
	.tarifa-tabla .ui-panelgrid-cell:first-child {
		padding-bottom: 5px;
	}
	.tarifa-tabla .ui-panelgrid-cell:first-child + .ui-panelgrid-cell {
		padding-top: 5px;
	}
}

@media (min-width: 641px) {
	.tarifa-tabla .ui-panelgrid-cell:first-child {
		padding-right: 5px;
	}
	.tarifa-tabla .ui-panelgrid-cell:first-child + .ui-panelgrid-cell {
		padding-left: 5px;
	}
}

/* Estilos para los simbolos matematicos en el bloque de calculo */

.math-left-symbol, .math-left-symbol-2, .math-right-symbol {
	position: absolute;
	top: 21px;
	font-size: 15px;
	font-weight: bold;
}

.math-left-symbol {
	left: 0;
}

.math-left-symbol-2 {
	left: 12px;
}

.math-right-symbol {
	right: 0;
}

.math-left-bracket:after {
	content: "(";
}

.math-right-bracket:after {
	content: ")";
}

/* Estilo para los panelgrid de costes (icio) */

.ui-panelgrid-coste .ui-grid-row {
	margin: 5px 0;
}

.ui-panelgrid-coste .ui-grid-row .ui-panelgrid-cell {
	margin: auto 0;
}

.ui-panelgrid-coste .coste-check, .ui-panelgrid-coste-vallado .coste-check-vallado {
	margin-top: 12px;
}

.ui-panelgrid-coste.labelOnlyMobile .coste-check, .ui-panelgrid-coste-vallado.labelOnlyMobile .coste-check-vallado {
	margin-top: 0;
}

@media (max-width: 640px) {
	.ui-panelgrid-coste .coste-check, .ui-panelgrid-coste-vallado .coste-check-vallado {
		margin-top: 0;
	}
}

/* Aumentamos el especiado de las listas de seleccion multiple (icio) */

.checkNivel .ui-chkbox{
	margin: 15px 0;
}

.checkCalidad .ui-chkbox{
	margin: 9px 0;
}

/* Padding 0 para las celdas de un panel ui-grid-responsive (icio) */

.ui-panelgrid-padding0 > .ui-grid-responsive > .ui-grid-row > .ui-panelgrid-cell {	
	padding: 0;
}

/* Columnas responsive (icio) */

.ui-grid-col-4-mod {
	width: 38.5%;
}

.ui-grid-col-1-mod {
    width: 8.33333%;
	padding: 4px 0 !important;
	float: left;
	box-sizing: border-box;
}

@media (max-width: 640px) {
	.ui-grid-responsive .ui-grid-col-1-mod, .ui-grid-responsive .ui-grid-col-4-mod {
	    width: 100%;
	    float: none;
	    padding: 4px 10px !important;
	}
}

/* Necesario en la vesión 6.2 de primefaces para que cuando el texto del chekbox no se ponga debajo del check cuando es largo*/
.ui-selectmanycheckbox td {
	display: flex;
	align-items: center;
	text-align: justify;
}

/* Estilos indicad de entorno */
.environtment-flag.login {
	padding: 20px 20px;
	margin: 20px 20px;
	position: absolute;
}

.environtment-flag:hover {
	cursor: pointer;
}

.environtment-flag {
	color: white;
	font-weight: bold;
	text-transform: capitalize;
	margin: 0px 20px;
	padding: 12px 20px;
	border-radius: 5px;
	opacity: 0.9;
	float: left;
	background-color: #2d2d2dcf;
	box-shadow: 0px 0px 3px #888888;
}

@media (max-width: 640px) {
	.environtment-flag {
		position: absolute;
		right: 0;
	}
}

.environtment-flag-tooltip {
	width: 250px;
	font-weight: normal;
	text-align: center;
}

.environtment-flag-int {
	background-color: #c4422b;
}

.environtment-flag-test {
	background-color: #2bb1c4;
}

.environtment-flag-dev {
	background-color: #2bb1c4;
}