body, html {
    height: 100%;
}
.body, html, h1, h2, h3, h4, h5, h6, span {
    font-family: 'Rawline','Raleway',sans-serif;
}
.bg-left {
    background-color: #123a78;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    flex-direction: column;
}

.breadcrumb {
    font-size: 14px; /* Fonte menor */
    padding: 0.25rem 0.5rem; /* Menos espaçamento */
    margin-bottom: 0; /* Remove margem inferior, se necessário */
}


.breadcrumb-item + .breadcrumb-item::before {
    font-family: "Font Awesome 5 Free";
    content: "\f054"; /* Unicode do chevron-right */
    font-weight: 700;
    padding: 0 0.5rem;
    color: #ced4da;
}


.tituloPagina {
    color: #0C326F;
    font-size: 41.8px;
    font-weight: 300;
}

.input-group .btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
}



/* Menu do usuário */
.br-sign-in {
    display: flex;
    align-items: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 10px;
    border-radius: 10px; /* Bordas arredondadas */
    background-color: #f0f0f0; /* Fundo cinza claro */
}

.br-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%; /* Bordas arredondadas */
    background-color: #ff8c00; /* Cor de fundo amarelo */
    color: white; /* Cor da letra */
    font-weight: 700; /* Peso da fonte */
    font-size: 1.6em; /* Tamanho da fonte */
    margin-right: 10px;
}

.text-weight-semi-bold {
    font-weight: 600;
}

.dropdown-menu-lg {
    width: 250px;
}

.rounded-container {
    background-color: #f9f9f9; /* Fundo cinza claro */
    border-radius: 10px; /* Bordas arredondadas */
    box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2); /* Sombra */
    z-index: 1;
    position: absolute;
    left: -100px;
}

.br-item {
    padding: 10px;
    font-size: 10px;
}

.card-header {
    color: #0C326F;
    font-weight: 600;
    font-size: 16px;

}

.card-title {
    color: #0C326F;
    font-weight: 600;
    font-size: 18px;
}

.titulo-gov {
    color: #0C326F;
    font-size: 18px;
}

.card-tools {
    margin-left: auto; /* Mover a barra de pesquisa para a direita */
}

input::placeholder {
    color: rgba(0, 0, 0, 0.3) !important;
}

select.form-select option[disabled] {
    color: rgba(0, 0, 0, 0.3) !important;
    font-weight: 300 !important;
}


.form-text {
    font-size: 12px;
    opacity: 0.6;
}

.input-group-text {
    background-color: #f8f8f8;
    border-color: transparent;
    font-size: 16.8px;
    font-weight: 500;
    padding: 0.375rem 24px; /* acompanha o input */
    line-height: 1.5;
    height: calc(1.5em + 0.75rem + 2px); /* mesmo cálculo do input */
    display: flex;
    align-items: center;
    border-radius: 4px;
    box-shadow: none !important;
    margin-top: 6px;
    margin-bottom: 6px;
}

.form-label {
    margin: 0px 0px 4px;
    color: #0c326f; /* Cor do texto */
    font-size: 14px; /* Tamanho da fonte */
    font-weight: 600; /* Peso da fonte */
    line-height: 1.45; /* Altura da linha */
}

.form-control {
    background-color: #FFFFFF; /* Cor de fundo */
    border-color: #888888; /* Cor da borda */
    font-size: 16.8px; /* Tamanho da fonte */
    border-radius: 4px; /* Raio da borda */
    display: block; /* Exibição */
    font-weight: 500;
    margin-top: 6px;
    margin-bottom: 6px;
    box-shadow: none !important;
    padding-left: 16px;
    padding-right: 16px;
}

.form-control:focus {
    border: 2px solid #c2850c; /* borda laranja e mais grossa */
    border-color: #c2850c; /* Cor da borda ao focar */
    outline: none; /* Remove o outline padrão */
    background-color: #e9ecef; /* Cor de fundo ao focar */
    font-weight: 500; /* Peso da fonte */
}

.form-control:hover {
    background-color: #e9ecef; /* Cor de fundo ao passar o mouse */
}

/* SELECT padrão com aparência igual ao form-control */
select.form-select {
    background-color: #FFFFFF;
    border-color: #888888; /* Cor da borda */
    font-size: 16.8px;
    border-radius: 4px;
    display: block;
    font-weight: 500;
    margin-top: 6px;
    margin-bottom: 6px;
    box-shadow: none !important;
    padding-left: 16px;
    padding-right: 16px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

/* Remove a setinha padrão e define visual coerente */
select.form-select::-ms-expand {
    display: none;
}

/* Foco com borda laranja */
select.form-select:focus {
    border: 2px solid #c2850c;
    outline: none;
    background-color: #e9ecef;
    font-weight: 500;
}


/* Estilo base da borda SEM foco */
.ts-wrapper .ts-control {
    border-color: #888888; /* Cor da borda */
    border-radius: 4px;
    padding: 0.375rem 0.75rem;
    background-color: #FFFFFF;
    font-size: 16.8px;
    font-weight: 500;
    margin-top: 6px;
    margin-bottom: 6px;
    min-height: calc(1.5em + 0.75rem + 2px); /* Altura equivalente ao Bootstrap 5 */
    box-shadow: none !important;
    padding-left: 16px;
    padding-right: 16px;
}

/* Tom Select - controle interno */
.ts-wrapper.form-select .ts-control {
    background-color: #f8f8f8 !important;
    border: none !important;
    border-radius: 4px;
    min-height: 38px;
    padding: 6px 12px;
    box-shadow: none;
}

/* Borda laranja ao focar qualquer TomSelect */
.ts-wrapper.focus .ts-control {
    border: 2px solid #c2850c !important;
    background-color: #e9ecef;
    box-shadow: none !important;
    font-weight: 500;
}

/* Corrige placeholder + input dentro do controle */
.ts-wrapper.form-select .ts-control input {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Ícone de erro no TomSelect */
.ts-wrapper.is-invalid .ts-control {
    border-color: #dc3545 !important;
    padding-right: 2rem !important; /* espaço pro ícone */
    background: none !important;    /* evita conflito */
    position: relative;
}

.ts-wrapper.is-invalid .ts-control::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0.75rem; /* ajusta a posição conforme teu layout */
    width: 1rem;
    height: 1rem;
    pointer-events: none;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

/* Aparência quando desabilitado */
.ts-wrapper.disabled .ts-control,
.ts-wrapper.ts-blocked .ts-control {
    background: #e9ecef;
    opacity: 1;
    cursor: not-allowed;
}
.ts-wrapper.ts-blocked .ts-dropdown { display: none !important; }






.required:after {
    content: " *";
    font-size: 16px;
    color: red;
}

/* Alinhamento do checkbox a esquerda, não remover. https://stackoverflow.com/questions/15975968/twitter-bootstrap-inline-checkbox-alignment-issue */
.checkbox-inline,
.checkbox-inline + .checkbox-inline {
    margin-left: 0;
    margin-right: 10px;
}

.checkbox-inline:last-child {
    margin-right: 0;

}

.radio-inline,
.radio-inline + .radio-inline {
    margin-left: 0;
    margin-right: 10px;
}

.radio-inline:last-child {
    margin-right: 0;
}

.input-group .form-control {
    border-radius: 4px 0 0 4px; /* Bordas arredondadas para o input */
}

.input-group .input-group-append .btn {
    border-radius: 0 4px 4px 0; /* Bordas arredondadas para o botão */
    background-color: #ffffff; /* Cor de fundo do botão */
    border-color: #888; /* Cor da borda do botão */
}

.input-group .input-group-append .btn:hover {
    background-color: #e9ecef; /* Cor de fundo ao passar o mouse */
}

.input-group .input-group-append .btn .fas {
    color: #1351b4 !important; /* Cor do ícone */
}

.btn {
    border-radius: 100em; /* Raio do botão */
    height: 40px; /* Altura padrão do botão */
    width: auto; /* Largura automática */
    background-color: transparent; /* Cor de fundo */
    border: 0; /* Sem borda */
    color: #000; /* Cor do texto (substitua por uma cor específica) */
    cursor: pointer; /* Cursor ao passar o mouse */
    display: inline-flex; /* Exibição em linha flexível */
    align-items: center; /* Alinhamento dos itens */
    justify-content: center; /* Justificação do conteúdo */
    font-size: 16px; /* Tamanho da fonte (substitua por um valor específico) */
    font-weight: 600; /* Peso da fonte semi-negrito */
    padding: 0 24px; /* Espaçamento interno */
    position: relative; /* Posição */
    text-align: center; /* Alinhamento do texto */
    vertical-align: middle; /* Alinhamento vertical */
    white-space: nowrap; /* Espaçamento do texto */
    overflow: hidden; /* Overflow */
}

.btn:focus {
    outline: 3px solid #c2850c; /* substitua por sua cor gov-br */
    outline-offset: 2px;
}

.btn-sm {
    height: 32px; /* Altura do botão */
}

.btn-block {
    width: 100%;
    margin-bottom: 10px; /* Espaçamento entre os botões */
}



.btn-primary {
    background-color: #1351b4; /* Cor de fundo */
    color: #fff; /* Cor do texto (substitua por uma cor específica) */
}

.btn-primary:hover {
    background-color: #396dc0; /* Cor ao passar o mouse, mais clara */
    border-color: #396dc0; /* Cor da borda ao passar o mouse, mais clara */
    border: 0; /* Sem borda */
}

.btn-success {
    background-color: #168821; /* Cor de fundo */
    color: #fff; /* Cor do texto (substitua por uma cor específica) */
}

.btn-success:hover {
    background-color: #3b9b45; /* Cor ao passar o mouse, mais clara */
    border-color: #3b9b45; /* Cor da borda ao passar o mouse, mais clara */
    border: 0; /* Sem borda */
}

.swal2-confirm.btn-primary {
    background-color: #1351b4; /* Cor de fundo */
    color: #ffffff; /* Cor do texto (substitua por uma cor específica) */
}

.swal2-confirm.btn-primary:hover {
    background-color: #396dc0; /* Cor ao passar o mouse, mais clara */
    border-color: #396dc0; /* Cor da borda ao passar o mouse, mais clara */
    border: 0; /* Sem borda */
}

.btn-outline-primary {
    background-color: transparent;
    color: #1351b4;
    border: 1px solid #1351b4;
}

.btn-outline-primary:hover {
    background-color: #d9e3f3;
    color: #396dc0;
    border-color: #396dc0; /* Cor da borda ao passar o mouse, mais clara */
}

.swal2-cancel.btn-outline-primary {
    background-color: transparent !important;
    color: #1351b4 !important;
    border: 1px solid #1351b4 !important;
}

.swal2-cancel.btn-outline-primary:hover {
    background-color: #d9e3f3 !important;
    color: #396dc0 !important;
    border-color: #396dc0 !important;
}

.btn-outline-success {
    background-color: transparent;
    border-color: #5cb85c;
    color: #5cb85c;
}

.btn-outline-success:hover {
    background-color: #5cb85c;
    color: white;
}

.btn-outline-info {
    background-color: transparent;
    border-color: #5bc0de;
    color: #5bc0de;
}

.btn-outline-info:hover {
    background-color: #5bc0de;
    color: white;
}

.btn-outline-warning {
    background-color: transparent;
    border-color: #f0ad4e;
    color: #f0ad4e;
}

.btn-outline-warning:hover {
    background-color: #f0ad4e;
    color: white;
}

.btn-outline-danger {
    background-color: transparent;
    color: #d9534f;
    border: 1px solid #d9534f;
}

.btn-outline-danger:hover {
    background-color: #d9534f;
    color: white;
}

.btn-outline-default {
    background-color: transparent;
    border-color: #777;
    color: #777;
}

.btn-outline-default:hover {
    background-color: #777;
    color: white;
}

.btn-circle {
    width: 32px; /* Ajuste conforme necessário */
    height: 32px; /* Ajuste conforme necessário */
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 0;
}

.tag-suave-dedt {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 8px;
    margin: 2px;
    display: inline-block;
    width: 100px;
    color: white;
    background-color: #333333;
}

.tag-suave-lacen {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 8px;
    margin: 2px;
    display: inline-block;
    width: 100px;
    color: white;
    background-color: #E52207;
}

.tag-suave-unidade {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 8px;
    margin: 2px;
    display: inline-block;
    width: 100px;
    color: white;
    background-color: #155BCB;
}

.tag-suave-sentinela {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 8px;
    margin: 2px;
    width: 100px;
    display: inline-block;
    color: black;
    background-color: #FFCD07;

}

.tag-suave-coordenacao {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 8px;
    margin: 2px;
    display: inline-block;
    width: 100px;
    color: white;
    background-color: #168821;
}

th{
    font-weight: 600;
    font-size: 14px;
    color: #1351B4 !important;
    background-color: #F0F0F0 !important;
    border-bottom: none;
}

td {
    vertical-align: middle;
    font-size: 14px;
}

td.truncate {
    max-width: 300px;            /* Define um limite fixo */
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}



.encerrado td:not(.td-acao) {
    opacity: 0.3;
}

.badge-primary{
    background-color: #071d41;
    color: #fff;
    font-weight: 400;
}

.badge-outline-primary {
    background-color: #FFF;
    color: #071d41;
    border: 1px solid #071d41; /* Adiciona a borda */
    font-weight: 400;
}


.badge-secondary{
    background-color: #333333;
    color: #F0F0F0;
    font-weight: 400;
}

.badge-disabled{
    background-color: #f8f8f8;
    color: #333333;
    font-weight: 400;
}

.badge-danger{
    background-color: #E52207;
    color: #fff;
    font-weight: 400;
}

.badge-warning{
    background-color: #FFCD07;
    color: #000000;
    font-weight: 400;
}

.badge-success{
    background-color: #168821;
    color: #fff;
    font-weight: 400;
}

.autor-info {
    font-size: 10px;
    text-align: right;
    margin: 0;
    font-weight: normal;
}

.flatpickr-calendar {
    background: transparent;
    opacity: 0;
    display: none;
    text-align: center;
    visibility: hidden;
    padding: 0;
    -webkit-animation: none;
    animation: none;
    direction: ltr;
    border: 0;
    font-size: 14px;
    line-height: 24px;
    border-radius: 5px;
    position: absolute;
    width: 307.875px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    background: #fff;
    -webkit-box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08);
    box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08)
}

.flatpickr-calendar.open, .flatpickr-calendar.inline {
    opacity: 1;
    max-height: 640px;
    visibility: visible
}

.flatpickr-calendar.open {
    display: inline-block;
    z-index: 99999
}

.flatpickr-calendar.animate.open {
    -webkit-animation: fpFadeInDown 300ms cubic-bezier(.23, 1, .32, 1);
    animation: fpFadeInDown 300ms cubic-bezier(.23, 1, .32, 1)
}

.flatpickr-calendar .inline {
    display: block;
    position: relative;
    top: 2px
}

.flatpickr-calendar.static {
    position: absolute;
    top: calc(100% + 2px)
}

.flatpickr-calendar.static.open {
    z-index: 999;
    display: block
}

.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
    -webkit-box-shadow: none !important;
    box-shadow: none !important
}

.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
    -webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
    box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6
}

.flatpickr-calendar .hasWeeks .dayContainer, .flatpickr-calendar .hasTime .dayContainer {
    border-bottom: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0
}

.flatpickr-calendar .hasWeeks .dayContainer {
    border-left: 0
}

.flatpickr-calendar.hasTime .flatpickr-time {
    height: 40px;
    border-top: 1px solid #e6e6e6
}

.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
    height: auto
}

.flatpickr-calendar:before, .flatpickr-calendar:after {
    position: absolute;
    display: block;
    pointer-events: none;
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    left: 22px
}

.flatpickr-calendar.rightMost:before, .flatpickr-calendar.arrowRight:before, .flatpickr-calendar.rightMost:after, .flatpickr-calendar.arrowRight:after {
    left: auto;
    right: 22px
}

.flatpickr-calendar.arrowCenter:before, .flatpickr-calendar.arrowCenter:after {
    left: 50%;
    right: 50%
}

.flatpickr-calendar:before {
    border-width: 5px;
    margin: 0 -5px
}

.flatpickr-calendar:after {
    border-width: 4px;
    margin: 0 -4px
}

.flatpickr-calendar.arrowTop:before, .flatpickr-calendar.arrowTop:after {
    bottom: 100%
}

.flatpickr-calendar.arrowTop:before {
    border-bottom-color: #e6e6e6
}

.flatpickr-calendar.arrowTop:after {
    border-bottom-color: #fff
}

.flatpickr-calendar.arrowBottom:before, .flatpickr-calendar.arrowBottom:after {
    top: 100%
}

.flatpickr-calendar.arrowBottom:before {
    border-top-color: #e6e6e6
}

.flatpickr-calendar.arrowBottom:after {
    border-top-color: #fff
}

.flatpickr-calendar:focus {
    outline: 0
}

.flatpickr-wrapper {
    position: relative;
    display: inline-block
}

.flatpickr-months {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.flatpickr-months .flatpickr-month {
    background: transparent;
    color: rgba(0, 0, 0, 0.9);
    fill: rgba(0, 0, 0, 0.9);
    height: 34px;
    line-height: 1;
    text-align: center;
    position: relative;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    overflow: hidden;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1
}

.flatpickr-months .flatpickr-prev-month, .flatpickr-months .flatpickr-next-month {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    text-decoration: none;
    cursor: pointer;
    position: absolute;
    top: 0;
    height: 34px;
    padding: 10px;
    z-index: 3;
    color: rgba(0, 0, 0, 0.9);
    fill: rgba(0, 0, 0, 0.9)
}

.flatpickr-months .flatpickr-prev-month.flatpickr-disabled, .flatpickr-months .flatpickr-next-month.flatpickr-disabled {
    display: none
}

.flatpickr-months .flatpickr-prev-month i, .flatpickr-months .flatpickr-next-month i {
    position: relative

}

.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month, .flatpickr-months .flatpickr-next-month.flatpickr-prev-month {

    left: 0
}

.flatpickr-months .flatpickr-prev-month.flatpickr-next-month, .flatpickr-months .flatpickr-next-month.flatpickr-next-month {

    right: 0;

}

.flatpickr-months .flatpickr-prev-month:hover, .flatpickr-months .flatpickr-next-month:hover {
    color: #1351b4;
    font-weight: bold;
}

.flatpickr-months .flatpickr-prev-month:hover svg, .flatpickr-months .flatpickr-next-month:hover svg {
    fill: #f64747
}

.flatpickr-months .flatpickr-prev-month svg, .flatpickr-months .flatpickr-next-month svg {
    width: 14px;
    height: 14px
}

.flatpickr-months .flatpickr-prev-month svg path, .flatpickr-months .flatpickr-next-month svg path {
    -webkit-transition: fill .1s;
    transition: fill .1s;
    fill: inherit;
}

.numInputWrapper {
    position: relative;
    height: auto
}

.numInputWrapper input, .numInputWrapper span {
    display: inline-block
}

.numInputWrapper input {
    width: 100%
}

.numInputWrapper input::-ms-clear {
    display: none
}

.numInputWrapper input::-webkit-outer-spin-button, .numInputWrapper input::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none
}

.numInputWrapper span {
    position: absolute;
    right: 0;
    width: 14px;
    padding: 0 4px 0 2px;
    height: 50%;
    line-height: 50%;
    opacity: 0;
    cursor: pointer;
    border: 1px solid rgba(57, 57, 57, 0.15);
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.numInputWrapper span:hover {
    background: rgba(0, 0, 0, 0.1)
}

.numInputWrapper span:active {
    background: rgba(0, 0, 0, 0.2)
}

.numInputWrapper span:after {
    display: block;
    content: "";
    position: absolute
}

.numInputWrapper span.arrowUp {
    top: 0;
    border-bottom: 0
}

.numInputWrapper span.arrowUp:after {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 4px solid rgba(57, 57, 57, 0.6);
    top: 26%
}

.numInputWrapper span.arrowDown {
    top: 50%
}

.numInputWrapper span.arrowDown:after {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid rgba(57, 57, 57, 0.6);
    top: 40%
}

.numInputWrapper span svg {
    width: inherit;
    height: auto
}

.numInputWrapper span svg path {
    fill: rgba(0, 0, 0, 0.5)
}

.numInputWrapper:hover {
    background: rgba(0, 0, 0, 0.05)
}

.numInputWrapper:hover span {
    opacity: 1
}

.flatpickr-current-month {
    font-size: 135%;
    line-height: inherit;
    font-weight: 300;
    color: inherit;
    position: absolute;
    width: 75%;
    left: 12.5%;
    padding: 7.48px 0 0 0;
    line-height: 1;
    height: 34px;
    display: inline-block;
    text-align: center;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
}

.flatpickr-current-month span.cur-month {
    font-family: inherit;
    font-weight: 700;
    color: inherit;
    display: inline-block;
    margin-left: .5ch;
    padding: 0
}

.flatpickr-current-month span.cur-month:hover {
    background: rgba(0, 0, 0, 0.05)
}

.flatpickr-current-month .numInputWrapper {
    width: 6ch;
    width: 7ch \0;
    display: inline-block
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: rgba(0, 0, 0, 0.9)
}

.flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: rgba(0, 0, 0, 0.9)
}

.flatpickr-current-month input.cur-year {
    background: transparent;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    cursor: text;
    padding: 0 0 0 .5ch;
    margin: 0;
    display: inline-block;
    font-size: inherit;
    font-family: inherit;
    font-weight: 300;
    line-height: inherit;
    height: auto;
    border: 0;
    border-radius: 0;
    vertical-align: initial;
    -webkit-appearance: textfield;
    -moz-appearance: textfield;
    appearance: textfield
}

.flatpickr-current-month input.cur-year:focus {
    outline: 0
}

.flatpickr-current-month input.cur-year[disabled], .flatpickr-current-month input.cur-year[disabled]:hover {
    font-size: 100%;
    color: rgba(0, 0, 0, 0.5);
    background: transparent;
    pointer-events: none
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
    appearance: menulist;
    background: transparent;
    border: none;
    border-radius: 0;
    box-sizing: border-box;
    color: inherit;
    cursor: pointer;
    font-size: inherit;
    font-family: inherit;
    font-weight: 300;
    height: auto;
    line-height: inherit;
    margin: -1px 0 0 0;
    outline: none;
    padding: 0 0 0 .5ch;
    position: relative;
    vertical-align: initial;
    -webkit-box-sizing: border-box;
    -webkit-appearance: menulist;
    -moz-appearance: menulist;
    width: auto
}

.flatpickr-current-month .flatpickr-monthDropdown-months:focus, .flatpickr-current-month .flatpickr-monthDropdown-months:active {
    outline: none
}

.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
    background: rgba(0, 0, 0, 0.05)
}

.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
    background-color: transparent;
    outline: none;
    padding: 0
}

.flatpickr-weekdays {
    background: transparent;
    text-align: center;
    overflow: hidden;
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 28px
}

.flatpickr-weekdays .flatpickr-weekdaycontainer {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1
}

span.flatpickr-weekday {
    cursor: default;
    font-size: 90%;
    background: transparent;
    color: rgba(0, 0, 0, 0.54);
    line-height: 1;
    margin: 0;
    text-align: center;
    display: block;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    font-weight: bolder
}

.dayContainer, .flatpickr-weeks {
    padding: 1px 0 0 0
}

.flatpickr-days {
    position: relative;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
    width: 307.875px
}

.flatpickr-days:focus {
    outline: 0
}

.dayContainer {
    padding: 0;
    outline: 0;
    text-align: left;
    width: 307.875px;
    min-width: 307.875px;
    max-width: 307.875px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: inline-block;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-around;
    justify-content: space-around;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1
}

.dayContainer + .dayContainer {
    -webkit-box-shadow: -1px 0 0 #e6e6e6;
    box-shadow: -1px 0 0 #e6e6e6
}

.flatpickr-day {
    background: none;
    border: 1px solid transparent;
    border-radius: 150px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #393939;
    cursor: pointer;
    font-weight: 400;
    width: 14.2857143%;
    -webkit-flex-basis: 14.2857143%;
    -ms-flex-preferred-size: 14.2857143%;
    flex-basis: 14.2857143%;
    max-width: 39px;
    height: 39px;
    line-height: 39px;
    margin: 0;
    display: inline-block;
    position: relative;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center
}

.flatpickr-day.inRange, .flatpickr-day.prevMonthDay.inRange, .flatpickr-day.nextMonthDay.inRange, .flatpickr-day.today.inRange, .flatpickr-day.prevMonthDay.today.inRange, .flatpickr-day.nextMonthDay.today.inRange, .flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover, .flatpickr-day:focus, .flatpickr-day.prevMonthDay:focus, .flatpickr-day.nextMonthDay:focus {
    cursor: pointer;
    outline: 0;
    background: #e6e6e6;
    border-color: #e6e6e6
}

.flatpickr-day.today {
    border-color: transparent;
    background-color: #fdf5e6;
    color: #d54309;
    font-weight: 600;
}

.flatpickr-day.today:hover, .flatpickr-day.today:focus {
    border-color: #959ea9;
    background: #959ea9;
    color: #fff
}

.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange, .flatpickr-day.selected.inRange, .flatpickr-day.startRange.inRange, .flatpickr-day.endRange.inRange, .flatpickr-day.selected:focus, .flatpickr-day.startRange:focus, .flatpickr-day.endRange:focus, .flatpickr-day.selected:hover, .flatpickr-day.startRange:hover, .flatpickr-day.endRange:hover, .flatpickr-day.selected.prevMonthDay, .flatpickr-day.startRange.prevMonthDay, .flatpickr-day.endRange.prevMonthDay, .flatpickr-day.selected.nextMonthDay, .flatpickr-day.startRange.nextMonthDay, .flatpickr-day.endRange.nextMonthDay {
    background: #569ff7;
    -webkit-box-shadow: none;
    box-shadow: none;
    color: #fff;
    border-color: #569ff7
}

.flatpickr-day.selected.startRange, .flatpickr-day.startRange.startRange, .flatpickr-day.endRange.startRange {
    border-radius: 50px 0 0 50px
}

.flatpickr-day.selected.endRange, .flatpickr-day.startRange.endRange, .flatpickr-day.endRange.endRange {
    border-radius: 0 50px 50px 0
}

.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
    -webkit-box-shadow: -10px 0 0 #569ff7;
    box-shadow: -10px 0 0 #569ff7
}

.flatpickr-day.selected.startRange.endRange, .flatpickr-day.startRange.startRange.endRange, .flatpickr-day.endRange.startRange.endRange {
    border-radius: 50px
}

.flatpickr-day.inRange {
    border-radius: 0;
    -webkit-box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
    box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6
}

.flatpickr-day.flatpickr-disabled, .flatpickr-day.flatpickr-disabled:hover, .flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay, .flatpickr-day.notAllowed, .flatpickr-day.notAllowed.prevMonthDay, .flatpickr-day.notAllowed.nextMonthDay {
    color: rgba(57, 57, 57, 0.3);
    background: transparent;
    border-color: transparent;
    cursor: default
}

.flatpickr-day.flatpickr-disabled, .flatpickr-day.flatpickr-disabled:hover {
    cursor: not-allowed;
    color: rgba(57, 57, 57, 0.1)
}

.flatpickr-day.week.selected {
    border-radius: 0;
    -webkit-box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
    box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7
}

.flatpickr-day.hidden {
    visibility: hidden
}

.rangeMode .flatpickr-day {
    margin-top: 1px
}

.flatpickr-weekwrapper {
    float: left
}

.flatpickr-weekwrapper .flatpickr-weeks {
    padding: 0 12px;
    -webkit-box-shadow: 1px 0 0 #e6e6e6;
    box-shadow: 1px 0 0 #e6e6e6
}

.flatpickr-weekwrapper .flatpickr-weekday {
    float: none;
    width: 100%;
    line-height: 28px
}

.flatpickr-weekwrapper span.flatpickr-day, .flatpickr-weekwrapper span.flatpickr-day:hover {
    display: block;
    width: 100%;
    max-width: none;
    color: rgba(57, 57, 57, 0.3);
    background: transparent;
    cursor: default;
    border: none
}

.flatpickr-innerContainer {
    display: block;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden
}

.flatpickr-rContainer {
    display: inline-block;
    padding: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.flatpickr-time {
    text-align: center;
    outline: 0;
    display: block;
    height: 0;
    line-height: 40px;
    max-height: 40px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

.flatpickr-time:after {
    content: "";
    display: table;
    clear: both
}

.flatpickr-time .numInputWrapper {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    width: 40%;
    height: 40px;
    float: left
}

.flatpickr-time .numInputWrapper span.arrowUp:after {
    border-bottom-color: #393939
}

.flatpickr-time .numInputWrapper span.arrowDown:after {
    border-top-color: #393939
}

.flatpickr-time.hasSeconds .numInputWrapper {
    width: 26%
}

.flatpickr-time.time24hr .numInputWrapper {
    width: 49%
}

.flatpickr-time input {
    background: transparent;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 0;
    border-radius: 0;
    text-align: center;
    margin: 0;
    padding: 0;
    height: inherit;
    line-height: inherit;
    color: #393939;
    font-size: 14px;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-appearance: textfield;
    -moz-appearance: textfield;
    appearance: textfield
}

.flatpickr-time input.flatpickr-hour {
    font-weight: bold
}

.flatpickr-time input.flatpickr-minute, .flatpickr-time input.flatpickr-second {
    font-weight: 400
}

.flatpickr-time input:focus {
    outline: 0;
    border: 0
}

.flatpickr-time .flatpickr-time-separator, .flatpickr-time .flatpickr-am-pm {
    height: inherit;
    float: left;
    line-height: inherit;
    color: #393939;
    font-weight: bold;
    width: 2%;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-align-self: center;
    -ms-flex-item-align: center;
    align-self: center
}

.flatpickr-time .flatpickr-am-pm {
    outline: 0;
    width: 18%;
    cursor: pointer;
    text-align: center;
    font-weight: 400
}

.flatpickr-time input:hover, .flatpickr-time .flatpickr-am-pm:hover, .flatpickr-time input:focus, .flatpickr-time .flatpickr-am-pm:focus {
    background: #eee
}

.flatpickr-input[readonly] {
    cursor: pointer
}
/* Botão de confirmação */
.swal2-confirm {
    border-radius: 100em; /* Raio do botão */
    height: 32px; /* Altura padrão do botão */
    width: auto; /* Largura automática */
    border: 0; /* Sem borda */
    cursor: pointer; /* Cursor ao passar o mouse */
    display: inline-flex; /* Exibição em linha flexível */
    align-items: center; /* Alinhamento dos itens */
    justify-content: center; /* Justificação do conteúdo */
    font-size: 16px; /* Tamanho da fonte (substitua por um valor específico) */
    font-weight: 600; /* Peso da fonte semi-negrito */
    padding: 0 24px; /* Espaçamento interno */
    position: relative; /* Posição */
    text-align: center; /* Alinhamento do texto */
    vertical-align: middle; /* Alinhamento vertical */
    white-space: nowrap; /* Espaçamento do texto */
    overflow: hidden; /* Overflow */
    background-color: #1351b4; /* Cor de fundo */
    color: #ffffff; /* Cor do texto */
}

.swal2-confirm:hover {
    background-color: #396dc0; /* Cor ao passar o mouse, mais clara */
    border-color: #396dc0; /* Cor da borda ao passar o mouse, mais clara */
    border: 0; /* Sem borda */
}

/* Botão de cancelamento */
.swal2-cancel {
    border-radius: 100em; /* Raio do botão */
    height: 32px; /* Altura padrão do botão */
    width: auto; /* Largura automática */
    cursor: pointer; /* Cursor ao passar o mouse */
    display: inline-flex; /* Exibição em linha flexível */
    align-items: center; /* Alinhamento dos itens */
    justify-content: center; /* Justificação do conteúdo */
    font-size: 16px; /* Tamanho da fonte (substitua por um valor específico) */
    font-weight: 600; /* Peso da fonte semi-negrito */
    padding: 0 24px; /* Espaçamento interno */
    position: relative; /* Posição */
    text-align: center; /* Alinhamento do texto */
    vertical-align: middle; /* Alinhamento vertical */
    white-space: nowrap; /* Espaçamento do texto */
    overflow: hidden; /* Overflow */
    background-color: transparent;
    color: #1351b4;
    border: 1px solid #1351b4;
}

.swal2-cancel:hover {
    background-color: #d9e3f3;
    color: #396dc0;
    border-color: #396dc0; /* Cor da borda ao passar o mouse, mais clara */
}

/* Aplica a cor específica a todos os ícones FontAwesome */
i.fas, i.fa, i.fal, i.far, i.fab {
    color: #1351b4 !important;
}

.fa-home, .fa-edit, .fa-eye, .fa-cog, .fa-sign-out-alt, .fa-bars, .fa-eye-slash{
    color: #1351b4 !important;
}

.accordion-header{
    --bg-color: transparent;
    background: transparent;
    border: 0;
    color: #1351b4;
    display: flex;
    font-size: 16.8px;
    justify-content: space-between;
    outline: none;
    text-align: left;
    text-decoration: none;
    width: 100%;
}

.nav-header{
    color: #0C326F !important; /* Cor do texto */
    font-size: 16.8px !important;
    font-weight: 600;
    text-align: center;
}

.nav-link {
    color: #1351b4 !important; /* Cor do texto */
    font-size: 14px;
}
.dropdown-header{
    font-weight: 600;
}
.dropdown-item{
    color: #1351b4 !important; /* Cor do texto */
}

.bs-stepper-content {
    position: relative;
    min-height: 200px; /* ou ajuste conforme o maior conteúdo */
}

.bs-stepper-content .content {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    display: none;
    transition: opacity 0.3s ease-in-out;
    opacity: 0;
}

.bs-stepper-content .content.active.dstepper-block {
    display: block;
    opacity: 1;
    z-index: 1;
}

.accordion-button {
    background-color: transparent;
    color: #0e3c82;
    transition: background-color 0.2s ease-in-out;
    font-size: 16px;
}

.accordion-button:hover {
    background-color: #e9f5ff;
}

.accordion-button:not(.collapsed) {
    background-color: #d9e3f3;
}

.accordion-button.collapsed {
    background-color: #fff;
    color: #0e3c82;
    opacity: 0.4;
    border: 1px;
}

.gov-tooltip {
    position: relative;
    cursor: help;
    display: inline-block;
    margin-left: 6px;
    color: #1351b4; /* Ícone azul */
}

.gov-tooltip::after {
    content: attr(data-tooltip);
    visibility: hidden;
    opacity: 0;
    width: max-content;
    max-width: 260px;
    background-color: #1351b4; /* Azul padrão gov.br */
    color: #fff; /* Texto branco */
    text-align: left;
    border-radius: 6px;
    padding: 6px 10px;
    position: absolute;
    z-index: 999;
    top: 120%;
    left: 50%;
    transform: translateX(-50%);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    font-size: 0.75rem;
    line-height: 1.2;
    transition: opacity 0.2s ease-in-out;
    pointer-events: none;
    border: 1px solid #0e3c82; /* borda azul mais escura */
}

.gov-tooltip::before {
    content: "";
    visibility: hidden;
    opacity: 0;
    position: absolute;
    top: 110%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: #1351b4 transparent transparent transparent;
    transition: opacity 0.2s ease-in-out;
    z-index: 999;
}

.gov-tooltip:hover::after,
.gov-tooltip:focus::after,
.gov-tooltip:hover::before,
.gov-tooltip:focus::before {
    visibility: visible;
    opacity: 1;
}

.card-footer {
    display: flex;
    justify-content: flex-end;
}

/* HEADER do stepper */
.bs-stepper.line .bs-stepper-header {
    border: 0;
    gap: .5rem;
    align-items: center;
}
.bs-stepper .step .step-trigger {
    background: none;
    border: 0;
    padding: .25rem .5rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.bs-stepper .bs-stepper-circle {
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background-color: #1351B4; color: #fff; font-weight: 600;
}
.bs-stepper .bs-stepper-label {
    color: #1351B4; font-weight: 600; font-size: .95rem;
}
.bs-stepper .line {
    flex: 1 1 auto; height: 2px; background: #E5E7EB; border: 0;
}

/* Estado desabilitado */
.bs-stepper .step .step-trigger[disabled],
.bs-stepper .step .step-trigger[aria-disabled="true"] {
    opacity: .6; cursor: not-allowed;
}
.bs-stepper .step.active .bs-stepper-circle {
    box-shadow: 0 0 0 3px rgba(19,81,180,.15);
}

/* CONTEÚDO com fade e sem “pulo” de layout */
.bs-stepper-content {
    position: relative;
    min-height: 280px; /* ajustável */
}
.bs-stepper-content .content {
    position: absolute; inset: 0;
    display: block; opacity: 0; pointer-events: none;
    transition: opacity .25s ease-in-out;
}
.bs-stepper-content .content.active.dstepper-block {
    opacity: 1; pointer-events: auto; z-index: 1;
}

/* Botão olhinho centralizado no input de senha */
.form-group.position-relative .toggle-password {
    position: absolute; right: .5rem; top: 50%; transform: translateY(-50%);
    border: 0; background: transparent; padding: 0 .25rem;
}

/* Força stepper em LINHA (horizontal) */
.bs-stepper.line .bs-stepper-header{
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    justify-content: center; /* ou space-between */
    gap: .5rem;
}

.bs-stepper.line .bs-stepper-header .step{
    display: flex;
    align-items: center;
}

.bs-stepper.line .bs-stepper-header .line{
    flex: 0 0 48px;         /* comprimento da linha entre steps */
    height: 2px;
    background: #E5E7EB;
    margin: 0 8px;
}

/* Garante que nenhuma regra vertical do plugin prevaleça */
.bs-stepper .line{
    width: auto !important;
    height: 2px !important;
}



.row.d-flex.align-items-stretch > section {
    display: flex;
    flex-direction: column;
}

.row.d-flex.align-items-stretch > section > .mb-3 {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.row.d-flex.align-items-stretch > section > .mb-3 > div {
    flex: 1;
    display: flex;
    flex-direction: column;
}


