/* Global CSS para formulários e tabelas Aqualar */

/* Container principal */
.meusfrm .frm-container {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
}


/* Estrutura do formulário */
.meusfrm .frm-wrap {
    display: grid;
    gap: 0.75rem;
    width: 100%;
    max-width: 100%;
    margin: 0;
}
.meusfrm .frm-wrap fieldset {
    border: 1px solid #ccc;
    border-radius: 0.5rem;
    padding: 0.15rem 1rem 1rem 1rem;
    background: #f2f2f2;
	margin: 0;
}


/* Fieldsets */
.meusfrm .frm-section {
    border: 1px solid #ccc;
    border-radius: 0.5rem;
    padding: 0.5rem 1rem 1rem 1rem;
    background: #f9f9f9;
    margin: 0;
}
.meusfrm .frm-section legend {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}


/* Campos */
.meusfrm .frm-field {
    display: flex;
    flex-direction: column;
}
.meusfrm .frm-field label {
    margin-bottom: 0;
	margin-left: 0.5rem;
    font-size: 0.85rem;
    font-weight: 500;
    color: #333;
}
.meusfrm .frm-section input,
.meusfrm .frm-section select,
.meusfrm .frm-section textarea {
	height: 2.1rem;
	resize: vertical;
    font-size: 0.85rem;
    font-weight: 500;
    color: #0066FF;
    background-color: #fff;
    padding: 0.25rem 0.5rem;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    width: 100%;
    box-sizing: border-box;
}


/* Campos readonly */
.meusfrm .frm-section input[readonly],
.meusfrm .frm-section textarea[readonly],
.meusfrm .frm-section select[readonly] {
    color: #000 !important;
    border-color: #cbd3da !important;
    color: #333 !important;
    font-weight: 600;
	background: #e9ecef;
}


/* Botões */
.meusfrm button {
    background: #2563eb;
    color: #fff;
    border: 1px solid #2563eb;
    padding: 0.6rem 0.8rem;
    border-radius: 0.5rem;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
    transition: background 0.2s, color 0.2s;
}
.meusfrm button:hover {
    background: #1e40af;
}
.meusfrm button.secondary {
    background: #fff;
    color: #2563eb;
    border: 2px solid #2563eb;
}
.meusfrm button.secondary:hover {
    background: #2563eb;
    color: #fff;
}


/* Barra de ações */
.meusfrm .frm-actions {
    display: flex;
    justify-content: space-between;
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid #ddd;
}
.meusfrm .frm-actions-left button,
.meusfrm .frm-actions-right button {
    margin-right: 0.5rem;
}
.meusfrm .frm-actions-right button:last-child {
    margin-right: 0;
}


/* Botões com ícones */
.meusfrm .frm-actions button i {
    margin-right: 0.35rem;
}

.dt-buttons{
	margin-bottom:8px;
}


/* Mensagens AJAX */
.meusfrm messages {
    display: none;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    margin-bottom: 0.75rem;
    font-weight: 600;
    font-size: 0.9rem;
}

.meusfrm messages.frm-success {
    background: #d4edda;
    border: 1px solid #b7dfb9;
    color: #155724;
}

.meusfrm messages.frm-error {
    background: #f8d7da;
    border: 1px solid #e4b9bd;
    color: #721c24;
}


/* Tabelas */
table.meusfrm-tabela{
	width:100%!important;
	font-size:0.85rem;
}
table.meusfrm-tabela thead tr.filtros{
	margin: 0;
	line-height: 0.5rem;
}
table.meusfrm-tabela thead tr.filtros th{
	vertical-align:top;
	padding: 0rem 0.25rem 0.15rem 0.25rem;
	margin: 0.15rem;
	background: #eee;
}
.meusfrm .dataTables_scrollHead th { 
	vertical-align: middle; 
	text-align: center;
}
.meusfrm .dataTables_length label{
	margin-left: 15px;
}
.meusfrm .dataTables_highlight { 
	background-color: yellow; 
	font-weight: bold; 
}
.meusfrm .dataTables_scrollBody td, 
.meusfrm .dataTables_scrollBody th { 
	vertical-align: middle; 
	text-align: center;
}
.meusfrm tbody td { 
		line-height: 1.2rem;
		vertical-align: middle; 
}
.meusfrm tbody tr:nth-child(odd) { 
		background-color: #fdfdfd; 
} 
.meusfrm tbody tr:nth-child(even) { 
		background-color: #e6f2ff;
}

a.meusfrm-abrir{
	padding:3px 8px;
	background:#0073aa;
	color:#fff!important;
	border-radius:3px;
	text-decoration:none;
}
.meusfrm .dataTables_info,
.meusfrm .dataTables_paginate,
.meusfrm .dataTables_filter label,
.meusfrm .dataTables_length label{
    font-size: 0.85rem;
    font-weight: 400;
}

/* Filtros */
.meusfrm-filter {
	color: black;
	border-color: black;
	font-weight: 600;
}
.meusfrm-filter-active {
	color: red;
	border-color: red;
	font-weight: 600;
}
.meusfrm-filter-wrapper{
	position:relative;
	display:flex;
	align-items:center;
	gap:6px;
	line-height: 1.5rem;
}
.meusfrm-filter-wrapper{
	position:relative;
	display:flex;
	align-items:center;
	gap:6px;
	line-height: 1.5rem;
}
.meusfrm-filter-wrapper .dashicons{
	display: inline-block;
	position:absolute;
	left:6px;
	color:#666;
	font-size:14px;
	line-height:1;
}
.meusfrm-filter-wrapper input.text-filter,
.meusfrm-filter-wrapper select.select-filter{
	width:100%;
	min-width:70px;
	font-size:11px;
	padding:4px 6px 4px 26px;
	border-width:1px;
	border-radius:3px;
	background:#fff;
}
.meusfrm-filter-wrapper input.date-min,
.meusfrm-filter-wrapper input.date-max{
	padding:4px 6px 4px 26px;
	min-width:90px;
	display:block;
	border-width:1px;
	border-radius:3px;
	background:#fff;
	margin-bottom:3px;
	
	height: 2.1rem; 
	box-sizing: border-box;
}
/* Tooltip */
.meusfrm-tooltip{
	position:relative;
	display:inline-block;
	margin-right:6px;
}
.meusfrm-tooltip .tooltip-text{
	position:absolute;
	z-index:999;
	background:#222;
	color:#fff;
	font-size:11px;
	padding:6px 8px;
	border-radius:4px;
	white-space:normal;
	max-width:220px;
	line-height:1.3;
	opacity:0;
	transform:translateY(4px);
	pointer-events:none;
	transition:opacity .15s ease, transform .15s ease;
}
.meusfrm-tooltip:hover .tooltip-text{
	opacity:1;
	transform:translateY(0);
}
.meusfrm-tooltip .tooltip-text.pos-bottom{
	top:100%;
	left:0;
	margin-top:6px;
}

/* Janela Modal */
.meusfrm-modal {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0,0,0,0.5);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.meusfrm-modal .modal-content {
    background: #fff;
    padding: 1.5rem;
    border-radius: 0.5rem;
    width: 300px;
}

.meusfrm-modal .modal-actions {
    margin-top: 1rem;
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

/* Responsividade */
@media (max-width: 900px) {
    .meusfrm .frm-grid,
    .meusfrm .frm-grid_top {
        grid-template-columns: repeat(8, 1fr);
    }
}

@media (max-width: 600px) {
    .meusfrm .frm-grid,
    .meusfrm .frm-grid_top {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Grid principal das secções */
.meusfrm .frm-grid {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    gap: 0.75rem;
}


/* Colunas utilitárias (1 a 16) */
.meusfrm .frm-col-1  { grid-column: span 1; }
.meusfrm .frm-col-2  { grid-column: span 2; }
.meusfrm .frm-col-3  { grid-column: span 3; }
.meusfrm .frm-col-4  { grid-column: span 4; }
.meusfrm .frm-col-5  { grid-column: span 5; }
.meusfrm .frm-col-6  { grid-column: span 6; }
.meusfrm .frm-col-7  { grid-column: span 7; }
.meusfrm .frm-col-8  { grid-column: span 8; }
.meusfrm .frm-col-9  { grid-column: span 9; }
.meusfrm .frm-col-10 { grid-column: span 10; }
.meusfrm .frm-col-11 { grid-column: span 11; }
.meusfrm .frm-col-12 { grid-column: span 12; }
.meusfrm .frm-col-13 { grid-column: span 13; }
.meusfrm .frm-col-14 { grid-column: span 14; }
.meusfrm .frm-col-15 { grid-column: span 15; }
.meusfrm .frm-col-16 { grid-column: span 16; }


/* Grid do topo (campos sem frame) */
.meusfrm .frm-grid_top {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    gap: 0.75rem;
    margin-left: 1rem;	
}
.meusfrm .frm-grid_top input {
	height: 2.1rem;
	resize: vertical;
    font-size: 0.85rem;
    font-weight: 600;
    color: #000;
    background: #e9ecef;
    padding: 0.25rem 0.5rem;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    width: 100%;
    box-sizing: border-box;
}



/* Checkboxes de água */
.meusfrm .frm-check {
	border: 1px solid #d1d5db;
  border-radius: 0.5rem;
	padding: 0rem 0.5rem 0rem 0.5rem;
	background: #fff;
}
.meusfrm .frm-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.meusfrm .frm-row label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    font-size: 0.85rem;
}
/* Estilos de linha com checkboxs */
.meusfrm .frm-row {
  gap: 2rem;
  align-items: flex-start;
  flex-wrap: wrap;
}
/* Textareas ao lado dos checkboxes */
.meusfrm .frm-row textarea {
    flex: 1;
    min-width: 200px;
}






/* ============================================================
   TABELA DE REFERÊNCIAS — ESTILOS ESPECÍFICOS
   ============================================================ */
.meusfrm .dataTables_filter input,
.meusfrm .dataTables_length select {
    background-color: #fff;
}





/* ============================================================
   FORMULÁRIO DE REFERÊNCIAS — ESTILOS ESPECÍFICOS
   ============================================================ */

/* botão para nova profissão */
.meusfrm .btn-nova-profissao {
	height: 2.1rem;
	width: 3rem;;
	padding: 0;
	font-size: 1.5rem;
}

/* labels mais pequenas */
.meusfrm .frm-field label[for='numero_ref'],
.meusfrm .frm-field label[for='e_cliente'],
.meusfrm .frm-field label[for='id_referencia'],
.meusfrm .frm-field label[for='id_marcacao'],
.meusfrm .frm-field label[for='id_campanha'] { 
	font-size: 0.7rem; 
}

/* texto maior */
.meusfrm .frm-field input[name="numero_ref"] { 
	font-size: 1.2rem;
	font-weight: bold;	
}