.singleLine {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.noShow {
	display: none;
}

.allPadding {
	padding: 10px !important;
}

.allMargin {
	margin: 5px;
}

.contentVerticalPadding {
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

.toRight {
	float: right;
}

.customLine {
	border: solid 1px #00abc2;
}

.text-button-primary {
	color: #00abc2;
}

.button-small {
	width: 18px !important;
	height: 18px !important;
}

.button-small-text {
	height: 18px !important;
	min-width: 100px !important;
}

.button-small-text .ui-button-text {
	padding: 0 1em 0.3em 2.1em !important;
}

div.clear {
	clear: both;
}

.alLeft {
	text-align: left;
}

.alRight {
	text-align: right;
}

.alTop {
	vertical-align: top;
}

.alMiddle {
	vertical-align: middle;
}

.alBottom {
	vertical-align: bottom;
}

.alCenter {
	text-align: center;
}

.alCenter table {
	margin: 0 auto;
	text-align: center;
}

.separatorTop {
	margin-top: 10px;
}

.separatorRight {
	padding-right: 10px;
}

.separatorBottom {
	padding-bottom: 10px;
}

.w100 {
	width: 100%;
}

.w90 {
	width: 90%;
}

.w85 {
	width: 85%;
}

.w75 {
	width: 75%;
}

.w66 {
	width: 66%;
}

.w55 {
	width: 55%;
}

.w50 {
	width: 50%;
}

.mw50 {
	min-width: 50%
}

.w45 {
	width: 45%;
}

.w40 {
	width: 40%;
}

.w33 {
	width: 33%;
}

.w30 {
	width: 30%;
}

.w25 {
	width: 25%;
}

.w20 {
	width: 20%;
}

.w15 {
	width: 15%;
}

.w12 {
	width: 12%;
}

.w10 {
	width: 10%;
}

.w8 {
	width: 8%;
}

.w5 {
	width: 5%;
}

.w20px {
	width: 20px;
}

.w40px {
	width: 40px;
}

.w60px {
	width: 60px;
}

.w70px {
	width: 70px;
}

.field_mrg {
	padding-left: 10px;
}

.field_mrg_x2 {
	padding-left: 20px;
}

.field_mrg_x4 {
	padding-left: 40px;
}

.bold {
	font-weight: bold;
}

.uppercase {
	text-transform: uppercase;
}

.encabezado, label.encabezado {
	font-weight: bold;
	display: block;
	margin-bottom: 11px;
}

.encabezado1_5emwm {
	font-weight: bold;
	display: block;
	font-size: 1.5em;
}

.encabezado1_5em {
	font-weight: bold;
	display: block;
	margin-bottom: 14px;
	margin-top: 14px;
	font-size: 1.5em;
}

.encabezado1_5em_clean {
	font-weight: bold;
	font-size: 1.5em;
}

.encabezado1_4em {
	font-weight: bold;
	display: block;
	margin-bottom: 14px;
	margin-top: 14px;
	font-size: 1.4em;
}

.encabezado1_3em {
	font-weight: bold;
	display: block;
	margin-bottom: 14px;
	margin-top: 14px;
	font-size: 1.3em;
}

.square60px {
	width: 60px !important;
	height: 60px;
}

.noMargins {
	margin: 0 !important;
}

table.panel_data {
	/*COLOR: BORDE*/
	border: 1px #C5C5C5 solid;
	border-collapse: separate;
	margin: 0px;
	padding: 0px;
}

table.panel_data td {
	/*COLOR: CELDAS DATOS*/
	text-align: left;
	background-color: #F5F5F5;
	padding: 5px;
}

table.panel_data th, table.panel_data th.header, table.panel_data td.header,
	table.panel_data tr.alt td.header {
	/*COLOR: CELDAS CABECERA*/
	text-align: right;
	background-color: #00aac3;
	padding-right: 7px;
	padding-left: 7px;
	vertical-align: top;
	font-weight: bold;
	color: #FFF;
}

table.panel_data tr.alt td.null, table.panel_data tr.alt td, table.tabla_lista tr.alt td
	{
	/*COLOR: FONDO TABLA*/
	background-color: #FFFFFF;
}

table.panel_data tr.dark td.null, table.panel_data tr.dark td {
	/*COLOR: CELDAS DATOS*/
	background-color: #F5F5F5;
}

table.panel_data th a, table.panel_data th.header a, table.panel_data td.header a
	{
	color: #000;
}

div.buttons {
	margin-top: 0px;
	padding-top: 10px;
	text-align: right;
}

.inline {
	display: inline;
}

.imgNoBorder {
	border: 0px;
}

.noBorder  .ui-datalist-content {
	border: none;
}

.border-radius50px {
	border-radius: 50px;
}

.border-radius50px-left {
	border-radius: 0 50px 50px 0;
}

#menu-principal {
	border: 1px solid #aaaaaa;
	width: 18%;
	margin-right: 10px;
	float: left;
	position: relative;
	height: auto;
	margin-bottom: 20px;
	margin-left: 10px;
	padding: 7px;
}

#menu-principal ul {
	list-style-type: none;
	margin: 0px;
	padding: 0px;
	font-family: Arial, sans-serif;
}

.icon-play {
	background-image: url("../resources/images/play-big.png") !important;
	width: 50px;
	height: 50px;
	margin-left: -25px !important;
	margin-top: -25px !important;
	left: 50%;
	top: 50%;
}

.content {
	float: right;
	width: 78%;
}

iframe.full {
	display: block; /* iframes are inline by default */
	border: none; /* Reset default border */
	height: 135vh; /* Viewport-relative units */
	width: 100%;
	overflow: scroll;
}

.verde {
	background: #D8F5D3;
	height: 30px
}

.rojo {
	background-color: #F5A9A9 !important;
	background-image: none !important;
	color: #000000 !important;
}

.text-red {
	color: #F00;
}

.celeste {
	background-color: #D1D5F3 !important;
	background-image: none !important;
	color: #000000 !important;
}

.centrar {
	text-align: center;
}

.column-vertical-top {
	vertical-align: top;
}

.buttonLogin {
	height: 55px;
	background-color: rgb(40, 185, 248);
	color: white !important;
	font-weight: bold !important;
}

.uiLabelHelpRight {
	position: relative;
	display: inline-block;
}

.uiLabelHelpRight>.ui-inputfield {
	padding-right: 32px !important;
	width: auto !important;
}

.uiLabelHelpRight>i:last-of-type {
	right: 8px;
	color: #6c757d;
}

.uiLabelHelpRight>i {
	position: absolute;
	top: 50%;
	margin-top: -8px;
}

.rowFormSeparation td {
	padding-top: 5px;
}

.ui-fileupload-content {
	border: none !important;
	padding: 0px;
}

a.text-decoration-none, a.text-decoration-none span {
	text-decoration: none !important;
}

.tdDisplayLargeText {
	display: block;
	max-height: 200px;
	overflow: auto;
	word-wrap: break-word;
}

.piButtons .ui-icon {
	margin-top: -6px !important;
}

.buttonHeaderPanel {
	margin-top: -4px !important;
}

.buttonHeaderPanel .ui-icon {
	left: 50% !important;
}

.ui-datepicker-unselectable span {
	background: #b9b5b5 !important;
}

.multipleLine {
	word-wrap: break-word;
}

.buttonTooltip .ui-icon {
	background-image:
		url("../javax.faces.resource/images/ui-icons_222222_256x240.png.jsf?ln=primefaces-suia")
		!important;
}

.ui-state-highlight .ui-icon {
	background-image:
		url("../javax.faces.resource/images/ui-icons_ffffff_256x240.png.xhtml?ln=primefaces-suia&v=11.0.0&e=11.0.6")
		!important;
}

.sectorImages {
	width: 220px;
}

.imagesMenu {
	width: 170px;
	border-style: outset;
	border-width: 4px;
	border-color: #b0e0ce;
	padding: 3px;
}

.buttonLarge {
	width: 170px !important;
}

.tdDisplayLargeText {
	display: block;
	max-height: 150px;
	overflow: auto;
	word-wrap: break-word;
}
.field-inline{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}

/* Tooltip cómodo para textos medianos */
.tt-long .ui-tooltip-text{
  max-width: 34rem;
  white-space: normal;
  overflow-wrap: break-word;
  line-height: 1.45;
  padding: .75rem .9rem;
}

/* Panel flotante ancho y con scroll si creciera */
.op-help{
  max-width: 36rem;
  max-height: 22rem;
  overflow: auto;
  line-height: 1.45;
  padding-right: .5rem;
}
/* Anchos / alineación por columna */
.form-grid .col-label{
  text-align: right;
  vertical-align: top;
  white-space: nowrap;
  padding-right: .6rem;
}
.form-grid .col-value{
  vertical-align: top;
}

/* Dentro de cada celda de valor: select + (i) en la misma línea */
.value-cell .inline-field{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  white-space: nowrap;    /* evita que el icono salte hacia abajo */
}

/* Icono tipo texto, sin “caja” de botón prominente */
.help-icon{
  padding: 0;             /* limpia padding del botón */
  min-width: 0;           /* para que no crezca */
  line-height: 1;
}

/* Tooltip legible */
.tt-long .ui-tooltip-text{
  max-width: 34rem;
  white-space: normal;
  overflow-wrap: break-word;
  line-height: 1.45;
  padding: .75rem .9rem;
}
.no-pad-acc .ui-accordion-content,
.no-pad-acc .ui-accordion-content.ui-widget-content {
  padding: 0 !important;
}
.no-pad-acc .ui-accordion-header.tab-faltante {
	background-color: #7afa7a !important;  /* fondo rojo claro */
	border-color: #3af78c !important;      /* borde rojo */
	color: #000000 !important;             /* texto rojo más oscuro */
	font-weight: bold;
}
.no-pad-acc .ui-accordion .ui-accordion-header.tab-observado {
    background-color: #ffcc00 !important;
    border: 1px solid #cc9900 !important;
    color: #000 !important;
}

.no-pad-acc .ui-accordion .ui-accordion-header.tab-solventado {
    background-color: #676663 !important;
    border: 1px solid #676663 !important;
    color: #000 !important;
}
.no-pad-acc .ui-accordion-header.tab-faltante1 {
	 font-weight: bold;
}
/* Restaura iconografía de Quill */
.ql-snow .ql-stroke { stroke: #444 !important; }
.ql-snow .ql-fill,
.ql-snow .ql-stroke.ql-fill { fill: #444 !important; }
.ql-snow .ql-picker, .ql-snow .ql-toolbar button { color: #444 !important; }

/* Si tu tema fuerza svg a fill/stroke blancos, neutralízalo dentro del editor */
.ql-toolbar svg { fill: none !important; stroke: currentColor !important; }

/* Aplica a este editor mediante una clase personalizada */
.te-detalle .ql-editor{
  white-space: pre-wrap;        /* respeta saltos y envuelve */
  overflow-wrap: anywhere;      /* rompe cadenas largas sin espacios */
  word-break: break-word;       /* respaldo para navegadores antiguos */
  overflow-x: hidden;           /* sin scroll horizontal */
}
/* Opcional: asegúrate que el contenedor no crezca más de su caja */
.te-detalle { 
  max-width: 100%;
  box-sizing: border-box;
}

.msg-inline {
    display: inline-block;
    margin-left: 5px;
    vertical-align: top;
}
