﻿:root {
    --circle-size: clamp(1.5rem, 5vw, 2.7rem);
    --spacing: clamp(0.25rem, 2vw, 0.5rem);
    --bs-dark-active: #2A2A2A !important;
    --bs-btn-border-color: #2A2A2A !important;
    --bs-btn-hover-border-color: #2A2A2A !important;
    --bs-btn-active-border-color: #2A2A2A !important;
    --bs-btn-disabled-bg: #2A2A2A !important;
    --bs-btn-disabled-border-color: #2A2A2A !important;
    --bs-heading-color: #2A2A2A !important;
    /*--bs-btn-bg: #2A2A2A !important;*/
    /*--bs-btn-hover-bg: #2A2A2A !important;*/
    /*--bs-btn-active-bg: #2A2A2A !important;*/
    /*--fonte-padrao: "Consolas", monospace;*/
}

html {
    /*    letter-spacing: 2px !important;*/
}

/* Aplicar globalmente */
body {
    /*font-family: 'Courier New', Courier, monospace;*/ /* Fonte monoespaçada */
    /*letter-spacing: 0.05em;*/ /* Ajuste o valor conforme necessário */
}

.page-break {
    page-break-after: always;
    display: block;
    height: 100vh; /* simula uma página */
}
@media print {
    .page-break {
        display: block;
        page-break-before: always; /* força antes */
        page-break-after: always; /* força depois */
    }
}

/* Estilos específicos para o select2 com botão de filtro ao lado */
.select2-com-filtro + .select2-container .select2-selection--single {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    height: 100%; /* Mantém o alinhamento */
}

    .select2-com-filtro + .select2-container .select2-selection--single .select2-selection__arrow {
        height: 100%;
    }

body {
    /*    letter-spacing: 1px !important;
*/
}

tr {
    font-family: 'Roboto', sans-serif !important;
}

input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(16%) sepia(95%) saturate(4000%) hue-rotate(350deg) brightness(85%) contrast(120%);
}

.text-disabled {
    color: gray;
}

.text-gray-900 {
    color: #2a2a2a !important;
}

.page-loader {
    z-index: 999999 !important;
}

.tooltip {
    z-index: 999998 !important;
}

/* SOFIA HELPERS ***************************************************************/
.sofia-h-100-p-sch {
    height: 100% !important;
    overflow-y: auto;
    overflow-x: hidden;
}

.sofia-h-500-sch {
    height: 500px !important;
    overflow-y: auto;
    overflow-x: hidden;
}

.sofia-h-300-sch {
    height: 300px !important;
    overflow-y: auto;
    overflow-x: hidden;
}

.sofia-h-250-sch {
    height: 250px !important;
    overflow-y: auto;
    overflow-x: hidden;
}

.sofia-h-200-sch {
    height: 200px !important;
    overflow-y: auto;
    overflow-x: hidden;
}


/* SOFIA LISTA *****************************************************************/
.badge.badge-sm.badge-circle {
    width: 1.2rem !important;
    height: 1.2rem !important;
}

.badge.badge-sm {
    min-width: 1.2rem !important;
    font-size: 0.8rem;
}

.container-xxl {
    max-width: calc(100% - 0px) !important;
}

.sofia-lista-fixed {
    table-layout: fixed;
    width: 70%; /* Ensure the table uses the full available width */
}

.sofia-lista-accordion {
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23071437'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-icon-transform: rotate(-180deg);
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%233E97FF'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

    .sofia-lista-accordion > tbody td.dtr-control:before {
        -webkit-mask-image: var(--bs-accordion-btn-icon) !important;
        mask-image: var(--bs-accordion-btn-icon) !important;
        height: 1.5rem !important;
    }

    .sofia-lista-accordion > tbody tr.parent td.dtr-control:before {
        -webkit-mask-image: var(--bs-accordion-btn-active-icon) !important;
        mask-image: var(--bs-accordion-btn-active-icon) !important;
        transform: var(--bs-accordion-btn-icon-transform) !important;
    }

    .sofia-lista-accordion > tbody td.child .dtr-details {
        width: 100%;
    }

    .sofia-lista-accordion > tbody td.child .dtr-title {
        width: 14px !important;
        min-width: 14px !important;
        max-width: 14px !important;
    }

    .sofia-lista-accordion > tbody td.child .dtr-data {
        width: 100%;
    }

    .sofia-lista-accordion > tbody td.child table {
        width: 100%;
    }

/*border-bottom border-gray-300 text-nowrap*/

/*{  Verificar com Fabrício a necessidade, pois está zuando com a visão de cards do atendimento*/
.sofia-lista tbody tr {
    border-color: var(--bs-gray-300) !important;
    /*border-bottom: 1px solid var(--bs-gray-300) !important;*/
    border-bottom: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
    white-space: nowrap !important;
}
/* SEED DRAG DROP UPLOAD ******************************************************/
.sofia-drag-area {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    border: 3px dashed #c1c1c1;
    margin-bottom: -20px;
    padding: 12px 0;
    border-radius: 0.475rem;
    height: 125px;
}

    .sofia-drag-area.active {
        border: 2px solid #1683ff;
    }


.sofia-drag-button {
    cursor: pointer;
}

.sofia-drag-remove {
    border-left: 3px solid #4B5675;
    padding: 0 4px 0 8px;
    cursor: pointer;
}

.sofia-drag-on {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.sofia-drag-off {
    display: none
}
/* SOFIA FORMULARIO ************************************************************/
.row > div {
    margin-bottom: 1px;
}

.drag-area {
    border: 2px dashed #ccc;
    padding: 20px;
    text-align: center;
    transition: background-color 0.3s;
}

    .drag-area.sofia-drag-over {
        background-color: #f5f5f5;
    }

.file-name-container {
    background-color: rgba(255, 0, 0, 0.1); /* Fundo vermelho claro */
    padding: 5px;
    border-radius: 5px;
    display: inline-block;
    margin-top: 10px;
    text-align: center;
    width: 100%;
}

    .file-name-container.invalid {
        background-color: rgba(128, 128, 128, 0.1); /* Fundo cinza claro */
    }

.remove-file {
    font-size: 20px; /* Aumentar o tamanho do "x" */
}


.validacao-false {
    border: 1px solid #f44336 !important;
}

.input-group {
    width: auto;
}

input:not([type="radio"], [type="checkbox"]), select, textarea {
    /* background-color: #f1f1f2 !important; deixava fundo das caixas de texto cinza */
    color: black;
}

/*span.form-select-solid {
    background-color: #f1f1f2 !important;
    border-color: #DBDFE9;
}*/

.txt-calendario {
    border-right: 0 none !important;
}

.btn-calendario {
    cursor: pointer;
    background-color: #f1f1f2;
    border-left: 0 none !important;
}

.sofia-fefeedback {
    display: block;
    margin-bottom: -20px;
    margin-top: 4px;
    color: #2a2a2a;
    font-size: 0.75rem;
    font-family: 'Montserrat', sans-serif;
    font-style: italic;
}


.sofia-feedback-required {
    color: #dc3545;
    /*font-weight: bold;*/
}

.contador-caracteres {
    /* ... outros estilos ... */
    background-color: rgba(255, 255, 255, 0.8);
    padding: 2px 5px;
    border-radius: 4px;
}

/* SOFIA OPTION (INPUT RADIO) **************************************************/

.sofia-option {
    display: flex;
    overflow: hidden;
    background-color: var(--bs-gray-200);
    border-radius: 25px;
    width: 50%;
    margin: 0 auto;
}

    .sofia-option > input {
        position: absolute !important;
        clip: rect(0, 0, 0, 0);
        height: 1px;
        width: 1px;
        border: 0;
        overflow: hidden;
    }

    .sofia-option > label {
        background-color: var(--bs-gray-200);
        color: var(--bs-gray-700);
        font-size: 14px;
        line-height: 1;
        text-align: center;
        padding: 8px 16px;
        sofia border-radius: 25px;
        width: calc(50% - 1px);
        transition: all 0.1s ease-in-out;
    }

        .sofia-option > label:hover {
            cursor: pointer;
        }

    .sofia-option > input:checked + label {
        background-color: var(--bs-danger);
        color: var(--bs-white);
    }

/* SOFIA STEPPER (TABS) ********************************************************/
.sofia-stepper {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-lista {
    display: flex;
}

.sofia-stepper-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-links.active > div.sofia-stepper-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-links.active > div.sofia-stepper-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-links.active > div.sofia-stepper-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-texto {
    padding: 8px 0;
}

.sofia-stepper-conteudo > .sofia-stepper-tab {
    display: none;
}

.sofia-stepper-conteudo > .active {
    display: block;
}


/* SOFIA STEPPER ***************************************************************/
.sofia-stepper-nav {
    display: block !important;
}

    .sofia-stepper-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER ATENDIMENTO INICIO ********************************************************/

.sofia-stepper-atendimento {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-atendimento-lista {
    display: flex;
}

.sofia-stepper-atendimento-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-atendimento-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-atendimento-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-atendimento-texto {
    padding: 8px 0;
}

.sofia-stepper-atendimento-conteudo > .sofia-stepper-atendimento-tab {
    display: none;
}

.sofia-stepper-atendimento-conteudo > .active {
    display: block;
}

.sofia-stepper-atendimento-nav {
    display: block !important;
}

    .sofia-stepper-atendimento-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-atendimento-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-atendimento-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-atendimento-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER ATENDIMENTO FIM ***************************************************************/



/* SOFIA STEPPER oferta INICIO ********************************************************/

.sofia-stepper-oferta {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-oferta-lista {
    display: flex;
}

.sofia-stepper-oferta-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-oferta-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-oferta-links.active > div.sofia-stepper-oferta-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-oferta-links.active > div.sofia-stepper-oferta-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-oferta-links.active > div.sofia-stepper-oferta-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-oferta-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-oferta-texto {
    padding: 8px 0;
}

.sofia-stepper-oferta-conteudo > .sofia-stepper-oferta-tab {
    display: none;
}

.sofia-stepper-oferta-conteudo > .active {
    display: block;
}

.sofia-stepper-oferta-nav {
    display: block !important;
}

    .sofia-stepper-oferta-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-oferta-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-oferta-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-oferta-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER oferta FIM ***************************************************************/


/* SOFIA STEPPER CLIENTE INICIO ********************************************************/

.sofia-stepper-cliente {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-cliente-lista {
    display: flex;
}

.sofia-stepper-cliente-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-cliente-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-cliente-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-cliente-texto {
    padding: 8px 0;
}

.sofia-stepper-cliente-conteudo > .sofia-stepper-cliente-tab {
    display: none;
}

.sofia-stepper-cliente-conteudo > .active {
    display: block;
}

.sofia-stepper-cliente-nav {
    display: block !important;
}

    .sofia-stepper-cliente-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-cliente-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-cliente-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-cliente-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER CLIENTE FIM ***************************************************************/


/* SOFIA STEPPER CLIENTE DEPENDENTE INICIO ********************************************************/

.sofia-stepper-clienteDependente {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-clienteDependente-lista {
    display: flex;
}

.sofia-stepper-clienteDependente-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-clienteDependente-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-clienteDependente-links.active > div.sofia-stepper-clienteDependente-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-clienteDependente-links.active > div.sofia-stepper-clienteDependente-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-clienteDependente-links.active > div.sofia-stepper-clienteDependente-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-clienteDependente-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-clienteDependente-texto {
    padding: 8px 0;
}

.sofia-stepper-clienteDependente-conteudo > .sofia-stepper-clienteDependente-tab {
    display: none;
}

.sofia-stepper-clienteDependente-conteudo > .active {
    display: block;
}

.sofia-stepper-clienteDependente-nav {
    display: block !important;
}

    .sofia-stepper-clienteDependente-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-clienteDependente-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-clienteDependente-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-clienteDependente-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER CLIENTE DEPENDENTE FIM ***************************************************************/



/* SOFIA STEPPER CLIENTE ResponsavelLegal INICIO ********************************************************/

.sofia-stepper-clienteResponsavelLegal {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-clienteResponsavelLegal-lista {
    display: flex;
}

.sofia-stepper-clienteResponsavelLegal-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-clienteResponsavelLegal-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-clienteResponsavelLegal-links.active > div.sofia-stepper-clienteResponsavelLegal-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-clienteResponsavelLegal-links.active > div.sofia-stepper-clienteResponsavelLegal-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-clienteResponsavelLegal-links.active > div.sofia-stepper-clienteResponsavelLegal-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-clienteResponsavelLegal-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-clienteResponsavelLegal-texto {
    padding: 8px 0;
}

.sofia-stepper-clienteResponsavelLegal-conteudo > .sofia-stepper-clienteResponsavelLegal-tab {
    display: none;
}

.sofia-stepper-clienteResponsavelLegal-conteudo > .active {
    display: block;
}

.sofia-stepper-clienteResponsavelLegal-nav {
    display: block !important;
}

    .sofia-stepper-clienteResponsavelLegal-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-clienteResponsavelLegal-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-clienteResponsavelLegal-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-clienteResponsavelLegal-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER CLIENTE ResponsavelLegal FIM ***************************************************************/



/* SOFIA STEPPER empresa INICIO ********************************************************/

.sofia-stepper-empresa {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-empresa-lista {
    display: flex;
}

.sofia-stepper-empresa-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-empresa-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-empresa-links.active > div.sofia-stepper-empresa-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-empresa-links.active > div.sofia-stepper-empresa-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-empresa-links.active > div.sofia-stepper-empresa-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-empresa-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-empresa-texto {
    padding: 8px 0;
}

.sofia-stepper-empresa-conteudo > .sofia-stepper-empresa-tab {
    display: none;
}

.sofia-stepper-empresa-conteudo > .active {
    display: block;
}

.sofia-stepper-empresa-nav {
    display: block !important;
}

    .sofia-stepper-empresa-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-empresa-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-empresa-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-empresa-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER empresa FIM ***************************************************************/



/* SOFIA SWITCH ****************************************************************/
.sofia-switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 20px;
}

    .sofia-switch input {
        opacity: 0;
        width: 0;
        height: 0;
    }

.sofia-slider {
    position: absolute;
    cursor: pointer;
    top: 4px;
    left: 0px;
    right: 8px;
    bottom: 4px;
    background-color: #ccc;
    -webkit-transition: .3s;
    transition: .3s;
}

    .sofia-slider:before {
        position: absolute;
        content: "";
        height: 20px;
        width: 20px;
        left: 0px;
        bottom: -4px;
        background-color: white;
        -webkit-transition: .3s;
        transition: .3s;
        box-shadow: 0 .5rem 1rem rgba(0,0,0,.15) !important;
    }

.sofia-switch input:checked + .sofia-slider {
    background-color: #E40520;
}

.sofia-switch input:focus + .sofia-slider {
    box-shadow: 0 0 1px #dc3545;
}

.sofia-switch input:checked + .sofia-slider:before {
    -webkit-transform: translateX(12px);
    -ms-transform: translateX(12px);
    transform: translateX(12px);
}

.sofia-slider.round {
    border-radius: 34px;
}

    .sofia-slider.round:before {
        border-radius: 50%;
    }

.sofia-slider .fa-ban {
    position: absolute;
    left: 4px;
    top: 0px;
    color: #f1416c;
}

.sofia-slider .fa-check {
    position: absolute;
    right: 4px;
    top: 0px;
    color: #2195f1;
}

/* SOFIA ALERTAS ***************************************************************/
#painel-alerta.active {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: transparent;
    z-index: 999999 !important;
}

.sofia-alerta {
    position: fixed;
    width: 405px !important;
    top: 25px;
    right: 30px;
    border-radius: 12px;
    padding: 20px 12px 20px 16px;
    box-shadow: 0 5px 10px rgba(0,0,0,0.1);
    overflow: hidden;
    transform: translateX(calc(100% + 30px));
    transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.35);
    z-index: 999998 !important;
}

    .sofia-alerta.active {
        transform: translateX(0%);
    }


.sofia-alerta-content {
    display: flex;
    align-items: center;
}

    .sofia-alerta-content i {
        display: flex;
        align-items: center;
    }

.sofia-alerta-message {
    display: flex;
    flex-direction: column;
    margin: 0 20px;
}

    .sofia-alerta-message .text {
        font-size: 14px;
        font-weight: 400;
    }

        .sofia-alerta-message .text.text-1 {
            font-weight: 600;
        }

.sofia-alerta-close {
    position: absolute;
    top: 10px;
    right: 15px;
    padding: 5px;
    cursor: pointer;
    opacity: 0.7;
}

    .sofia-alerta-close:hover {
        opacity: 1;
    }

.sofia-alerta-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    width: 100%;
    background: #ddd;
}

    .sofia-alerta-progress:before {
        content: '';
        position: absolute;
        bottom: 0;
        right: 0;
        height: 100%;
        width: 100%;
        background-color: #4070f4;
    }

    .sofia-alerta-progress.active:before {
        animation: progress 5s linear forwards;
    }

/* SOFIA CONFIGURAÇÃO **********************************************************/
.sofia-btn-config {
    border-top: 1px solid #f1f1f1;
    border-left: 1px solid #f1f1f1;
    -webkit-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.75);
    box-shadow: 3px 3px 5px 1px rgba(0,0,0,0.15)
}

.sofia-dialer button {
    max-height: 34.81px !important;
}

.sofia-dialer span {
    background-color: #f1f1f2 !important;
    width: 40%;
    max-height: 34.81px !important;
    border-top-color: #dbdfe9 !important;
    border-bottom-color: #dbdfe9 !important;
}

.sofia-dialer input[type="text"] {
    text-align: right;
    max-width: 34%;
    max-height: 34.81px !important;
    border-top-color: #dbdfe9 !important;
    border-bottom-color: #dbdfe9 !important;
}

.sofia-config-img div.image-input {
    border: 3px dashed #c1c1c1;
}

.sofia-config-img div.image-input-changed {
    border: 3px solid #c1c1c1 !important;
}

.sofia-config-img div.image-input-wrapper {
    border-radius: 0 !important;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center !important;
}

.sofia-config-img div.sofia-config-img-empty {
    font-family: 'Poppins', sans-serif;
}

.sofia-config-img span.sofia-config-img-text {
    font-size: 18px;
    font-weight: 500;
    color: #34495e;
}

.sofia-config-img span.sofia-config-img-exts {
    font-size: 12px;
    color: gray;
    margin: 15px 0;
}

/* configuração de cards param tabelas */
.cards tbody tr {
    float: left;
    width: 22.6rem;
    margin: 0.6rem;
    border: 0.0625rem solid rgba(0, 0, 0, .125);
    border-radius: .25rem;
    box-shadow: 0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.25);
}

.cards tbody td {
    display: block;
    margin: 0 auto;
    text-align: center !important;
}

.cards thead {
    display: none;
}

.cards td:before {
    content: attr(data-label);
    position: relative;
    float: left;
    color: #808080;
    min-width: 4rem;
    margin-left: 0;
    margin-right: 1rem;
    text-align: center !important;
}

tr.selected td:before {
    color: #CCC;
}

.table .avatar {
    width: 50px;
}

.cards .avatar {
    width: 150px;
    height: 150px;
    margin: 15px;
}


@keyframes progress {
    100% {
        right: 100%;
    }
}
/* SOFIA MEDIA QUERIES *********************************************************/
@media (min-width: 576px) {
    .stepper-nav:before {
        top: 0;
        width: 0;
        left: 0;
    }
}

@media (min-width: 768px) {
    .stepper-nav:before {
        top: 100px;
        width: calc(100% - 208px);
        left: 104px;
    }
}

@media (min-width: 992px) {
    .stepper-nav:before {
        top: 108px;
        width: calc(100% - 308px);
        left: 154px;
    }
}


@media (min-width: 576px) {
    .sofia-stepper:before {
        top: 0;
        width: 0;
        left: 0;
    }
}

@media (min-width: 768px) {
    .sofia-stepper:before {
        top: 100px;
        width: calc(100% - 208px);
        left: 104px;
    }
}

@media (min-width: 992px) {
    .sofia-stepper:before {
        top: 108px;
        width: calc(100% - 308px);
        left: 154px;
    }
}


/* SOFIA STEPPER ATENDIMENTO INICIO ********************************************************/

.sofia-stepper-atendimento {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-atendimento-lista {
    display: flex;
}

.sofia-stepper-atendimento-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-atendimento-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-atendimento-links.active > div.sofia-stepper-atendimento-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-atendimento-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-atendimento-texto {
    padding: 8px 0;
}

.sofia-stepper-atendimento-conteudo > .sofia-stepper-atendimento-tab {
    display: none;
}

.sofia-stepper-atendimento-conteudo > .active {
    display: block;
}

.sofia-stepper-atendimento-nav {
    display: block !important;
}

    .sofia-stepper-atendimento-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-atendimento-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-atendimento-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-atendimento-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER ATENDIMENTO FIM ***************************************************************/


/* SOFIA STEPPER CLIENTE INICIO ********************************************************/

.sofia-stepper-cliente {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-cliente-lista {
    display: flex;
}

.sofia-stepper-cliente-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-cliente-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-cliente-links.active > div.sofia-stepper-cliente-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-cliente-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-cliente-texto {
    padding: 8px 0;
}

.sofia-stepper-cliente-conteudo > .sofia-stepper-cliente-tab {
    display: none;
}

.sofia-stepper-cliente-conteudo > .active {
    display: block;
}

.sofia-stepper-cliente-nav {
    display: block !important;
}

    .sofia-stepper-cliente-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-cliente-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-cliente-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-cliente-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER CLIENTE FIM ***************************************************************/





/* SOFIA STEPPER importacao INICIO ********************************************************/

.sofia-stepper-importacao {
    margin-top: 12px;
    display: block !important;
}

.sofia-stepper-importacao-lista {
    display: flex;
}

.sofia-stepper-importacao-itens {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-align: center;
}

    .sofia-stepper-importacao-itens:not(:last-child):after {
        content: "";
        position: relative;
        top: calc(var(--circle-size) / 2);
        width: calc(100% - var(--circle-size) - calc(var(--spacing) * 2));
        left: calc(50% + calc(var(--circle-size) / 2 + var(--spacing)));
        height: 3px;
        background-color: #e0e0e0;
        order: -1;
    }

.sofia-stepper-importacao-links.active > div.sofia-stepper-importacao-icone {
    background-color: #dc3545 !important;
}

    .sofia-stepper-importacao-links.active > div.sofia-stepper-importacao-icone > i {
        color: #FFFFFF !important;
    }

.sofia-stepper-importacao-links.active > div.sofia-stepper-importacao-texto > h3 {
    color: #dc3545 !important;
}

.sofia-stepper-importacao-icone {
    width: var(--circle-size);
    height: var(--circle-size);
    margin: 0 auto !important;
    border-radius: 25px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sofia-stepper-importacao-texto {
    padding: 8px 0;
}

.sofia-stepper-importacao-conteudo > .sofia-stepper-importacao-tab {
    display: none;
}

.sofia-stepper-importacao-conteudo > .active {
    display: block;
}

.sofia-stepper-importacao-nav {
    display: block !important;
}

    .sofia-stepper-importacao-nav:before {
        position: absolute;
        content: " ";
        height: 4px;
        background-color: #ccc;
        z-index: 0;
    }

.sofia-stepper-importacao-item {
    display: block !important;
    text-align: center !important;
    position: relative !important;
}

.sofia-stepper-importacao-icon {
    margin: 0 auto !important;
    border-radius: 25px !important;
}

.sofia-stepper-importacao-title {
    margin: 0 !important;
    padding: 8px 0 0 0 !important;
    font-size: 1rem !important;
}

/* SOFIA STEPPER IMPORTACAO FIM ***************************************************************/




/*Animação defs girar 360 graus*/


@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

.spin {
    display: inline-block;
    animation: spin 1.5s linear infinite;
    transform-origin: 50% 50%;
    transform-box: fill-box;
}


.loading-dots::after {
    content: '.';
    animation: dots 2.5s steps(5, end) infinite;
}

@keyframes dots {
    0%, 20% {
        content: '.';
    }

    40% {
        content: '..';
    }

    60% {
        content: '...';
    }

    80%, 100% {
        content: '';
    }
}
/* FIM Animação defs girar 360 graus*/

/*Animação defs girar 360 graus*/

.hide-table {
    visibility: hidden;
    background-color: #F9F9F9;
}

.show-table {
    visibility: visible;
    background-color: transparent;
}

.alert-no-border {
    border: none; /* Remove a borda */
    background-color: #f8d7da; /* Ajusta a cor de fundo, se necessário */
    color: #721c24; /* Mantém o texto na cor desejada */
    padding: 15px;
    border-radius: 5px; /* Ajuste o arredondamento conforme necessário */
}


/* Dropdown nas listas - INICIO*/


/* Centraliza o ícone e remove a seta do botão */
.dropdown-toggle::after {
    display: none; /* Remove a seta padrão do Bootstrap */
}

.dropdown-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px; /* Ajusta a largura para deixar o botão mais compacto */
    height: 30px; /* Ajusta a altura para deixar o botão mais compacto */
    padding: 0; /* Remove o padding interno */
    border-radius: 50%; /* Deixa o botão circular */
    background-color: transparent; /* Fundo transparente */
    border: none; /* Remove a borda */
}

.dropdown-menu.dropdown-compact {
    min-width: 100px; /* Largura mínima para o dropdown */
    padding: 4px; /* Reduz o padding */
}

    .dropdown-menu.dropdown-compact .dropdown-item {
        font-size: 0.85rem; /* Reduz o tamanho do texto */
        padding: 4px 10px; /* Compacta o item do dropdown */
    }

/* Define o tamanho da fonte e ajusta o padding para diminuir o retângulo */
.dropdown-menu .dropdown-item {
    font-size: 0.4rem; /* Reduz o tamanho da fonte */
    padding: 4px 8px; /* Ajusta o padding para deixar o retângulo mais fino */
}

.dropdown-menu {
    transform: translateX(10px) !important; /* Ajuste o valor conforme necessário */
}


/* INICIO ESTILO BOTÕES E ICONES SOFIA ***************************************************************/


/* Icones */
.fa-plus, .fa-trash, .fa-pen, .fa-circle-right, .fa-eye, .fa-rotate-left, .fa-ellipsis, .fa-print, .fa-ellipsis-vertical, .fa-clock {
    color: #7C7C7C !important;
    width: 16px;
    height: 16px;
}

.remove-standard {
    width: 32px;
    height: 32px;
    border: none !important;
    padding: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    justify-content: center;
    margin-left: 10px;
    border-radius: 50%;
    background-color: #EBEAEA;
    align-items: center;
}

.regra-opcoes {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: #EBEAEA;
    padding: 10px;
}

.td-span-status {
    width: 75%;
    display: inline-block;
}

/* Estilo para o botão novo*/

button.plus-btn {
    width: 98px;
    height: 40px;
    background-color: #FFFFFF;
    border: 1px solid #2a2a2a !important;
    ;
    color: #2a2a2a !important;
    ;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 16px;
    display: flex;
    align-items: center;
    gap: 3.2px;
    border-radius: 8px;
}

button.limparcache {
    width: 160px;
    height: 40px;
    background-color: #FFFFFF;
    border: 1px solid #2a2a2a !important;
    ;
    color: #2a2a2a !important;
    ;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 24px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 16px;
    display: flex;
    align-items: center;
    gap: 3.2px;
    border-radius: 8px;
}

.plus-btn .icon {
    font-size: 16px;
    font-weight: 900;
    line-height: 16px;
    text-align: center;
    color: #2a2a2a !important;
    ;
}

/* Estilo para a barra de pesquisa*/

button.filter-btn {
    width: 185px;
    height: 40px;
    border: 1px solid #2a2a2a !important;
    ;
    color: #2a2a2a !important;
    ;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    justify-content: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    border-radius: 8px;
    background: transparent;
}

.filter-btn .icon {
    font-size: 16px;
    color: #2a2a2a !important;
    ;
    margin-right: 8px;
}

.searchbutton {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    width: 40px;
    height: 40px;
    border-radius: 8px 8px 8px 0px;
    border: 1px solid #EEEEEE;
    background: #EEEEEE;
}

.btn-modelo-importacao {
    color: #E40520;
    background-color: #fff;
    border: 1px solid #E40520 !important;
}

.importacao-icon {
    color: #E40520 !important;
}

.btn-custom-danger {
    color: #fff;
    background-color: #E40520;
    border: none !important;
    height: 40px !important;
    border-radius: 0px 8px 8px 0px !important;
}

    .btn-custom-danger:hover {
        color: #fff;
        background-color: #c1041a;
        border-color: #b30418;
    }

    .btn-custom-danger:focus,
    .btn-custom-danger.focus {
        box-shadow: 0 0 0 0.2rem rgba(228, 5, 32, 0.5);
    }

    .btn-custom-danger:active,
    .btn-custom-danger.active {
        background-color: #b30418;
        border-color: #a00315;
    }

    .btn-custom-danger:disabled,
    .btn-custom-danger.disabled {
        background-color: #E40520;
        border-color: #E40520;
        opacity: 0.65;
    }

    .btn-custom-danger i {
        color: inherit;
    }

i.search-icon {
    font-size: 16px;
    color: #E40520;
}

/*i.fa-solid.fa-magnifying-glass {
    font-size: 16px !important;
    color: #2a2a2a !important; !important;
}*/


/* Estilo para o botão limpar*/
button.clear-btn {
    width: 114px;
    height: 40px;
    background-color: #FFFFFF;
    border: 1px solid #2a2a2a !important;
    color: #2a2a2a !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    justify-content: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    border-radius: 8px;
    background: transparent;
}

.clear-btn .icon {
    font-size: 16px;
    font-weight: 900;
    line-height: 16px;
    text-align: center;
    color: #2a2a2a !important;
    margin-right: 8px;
}

/* Estilo para os botões cancelar e finalizar em massa*/

button.massa-btn {
    width: 102px;
    height: 40px;
    border: 1px solid #2a2a2a !important;
    color: #2a2a2a !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 12.8px;
    font-weight: 500;
    line-height: 19.2px;
    text-align: left;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 6.4px 6.4px;
    display: flex;
    align-items: center;
    gap: 3.2px;
    border-radius: 6.4px;
    background-color: transparent;
}

.massa-btn .icon {
    font-size: 15px;
    color: #2a2a2a !important;
    ;
    margin-right: 8px;
}

/* Estilo para o botão card*/

.card-button {
    width: 88px;
    height: 32px;
    padding: 4px 16px 4px 16px;
    gap: 10px;
    border-radius: 20px;
    border: 1px solid #BCB8B8;
    float: right;
    max-width: 150px;
    opacity: 1;
    align-items: center;
}

.btn-active {
    color: #2a2a2a !important;
    background: #EEEEEE;
}

.btn-inactive {
    color: #6c757d !important;
    font-size: 16px;
}

/* Estilo para o botão importar inscritos*/

button.import-btn {
    width: 200px;
    height: 40px;
    border: 1px solid #2a2a2a !important;
    ;
    color: #2a2a2a !important;
    ;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    justify-content: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    border-radius: 8px;
    background: transparent;
}

.import-btn .icon {
    font-size: 16px;
    color: #2a2a2a !important;
    ;
    margin-right: 8px;
}

/* Estilo para o botão expandir/recolher menu */
.custom-sidebar-toggle {
    display: flex; /* Certifique-se de que o botão também é flexível */
    align-items: center; /* Alinha verticalmente */
    justify-content: center; /* Centraliza horizontalmente */
    margin: 8px 8px; /* Centraliza no eixo principal (vertical) */
    background: #FFFFFF; /* Fundo branco, conforme necessário */
    width: 40px; /* Largura fixa */
    height: 40px; /* Altura fixa */
    border-radius: 8px; /* Arredondamento, se necessário */
    position: absolute;
}

    /* Sobrescrevendo propriedades do Keen Themes somente no contexto desejado */
    .custom-sidebar-toggle .rotate {
        transform: rotate(0deg); /* Ajuste específico */
    }

    /* Para estados ativos (se necessário) */
    .custom-sidebar-toggle[data-kt-toggle-state="active"] {
        background: #FFFFFF; /* Exemplo de cor ao ativar */
    }

/* Estilo do botão pesquisar */
button.pesquisar-btn {
    width: 120px;
    height: 40px;
    background-color: #FFFFFF;
    border: 1px solid #2a2a2a !important;
    ;
    color: #2a2a2a !important;
    ;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: center;
    justify-content: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    border-radius: 8px;
    background: transparent;
}

.pesquisar-btn .icon {
    font-size: 16px;
    color: #2a2a2a !important;
    ;
    margin-right: 8px;
}

.check-style {
    border: 1px solid #7C7C7C !important;
    border-radius: 4px;
}

.criacao {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #FED386;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.cancelada {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #FDC9CB;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.aberta {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #A5EFC6;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.rascunho {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #9CB8FC;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.iniciada {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #FED386;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
}

.badge-info {
    color: black !important;
    background-color: #FED386 !important;
}

.badge-danger, .badge-warning {
    color: #FFF;
    background-color: #E40520;
}

.badge-success {
    color: #FFF;
    background-color: #37B370;
}

.finalizada {
    width: 84px;
    height: 23px;
    padding: var(--spacingspacing-xs) var(--spacingspacing-sm) var(--spacingspacing-xs) var(--spacingspacing-sm);
    gap: var(--spacingspacing-xs);
    border-radius: 4px;
    background: #2a2a2a !important;
    ;
    color: #FFFFFF;
    font-family: 'Montserrat', sans-serif;
    font-size: 12px;
    font-weight: 500;
    line-height: 14.63px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    text-underline-position: from-font;
    text-decoration-skip-ink: none;
    color: white;
}

.nome-unidade {
    color: #E40520 !important;
}

.btn-success {
    background: transparent !important;
    border: 1px solid #2A2A2A !important;
    color: #2A2A2A !important;
}

:root {
    --bs-success-active: transparent;
}

.ki-plus {
    color: #2a2a2a !important;
    !important;
}

.text-danger {
    color: #E40520 !important;
}

.bg-danger {
    background-color: #E40520 !important;
}

text-black {
    color: #2a2a2a !important;
    !important;
}

.text-hover-danger:hover {
    color: #2a2a2a !important;
    !important;
}

.menu-item:hover .menu-icon i {
    color: #2a2a2a !important;
    !important; /* força a aplicação da cor */
}


/* FIM ESTILO BOTÕES SOFIA ***************************************************************/
.page-loading-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: white;
    width: 120px; /* Largura do fundo */
    height: 120px; /* Altura do fundo */
    border-radius: 8px; /* Borda arredondada opcional */
    z-index: 1050; /* Certifique-se de que está acima dos elementos normais */
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra para destacar */
}

.text-stripped {
    text-decoration: line-through; /* Adiciona a linha sobre o texto */
    color: darkred;
}

.color-cinza {
    color: var(--bs-gray-700) !important;
}
.bg-cinza {
    background-color: #EBEAEA
}

    .bg-cinza:focus {
        background-color: #EBEAEA
    }

/* Estilização para evitar truncamento do menu colapse*/
.menu-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 768px) {
    .menu-title {
        font-size: 0.9rem;
    }
}

.menu-sub {
    max-height: 300px;
    overflow-y: auto;
}

/* Remove a borda padrão azul do Bootstrap (se necessário) */
.nav-link {
    border-color: transparent;
}

    /* Estiliza o hover nos nav-links para manter consistência */
    .nav-link:hover {
        color: #dc3545; /* Vermelho no hover */
        border-color: transparent; /* Mantém transparente ao passar o mouse */
    }

.dimmed-modal {
    filter: brightness(0.5); /* Dim the modal without affecting interaction */
}


.nav-tabs .nav-link {
    border-bottom: 3px solid transparent; /* Remove borda padrão inicial */
    color: #6c757d; /* Cor padrão para abas inativas */
}

    .nav-tabs .nav-link.active {
        border-bottom: 3px solid #2a2a2a !important;
        !important; /* Mantém a borda vermelha para a aba ativa */
        color: #2a2a2a !important;
        !important; /* Mantém o texto vermelho para a aba ativa */
    }

/*Para não gerar scroll na tela onde tem as grids*/
.dataTables_scrollBody {
    height: 460px !important;
    max-height: none !important;
}

/* Sobrescrevendo fundo de qualquer classe "dark" */
.table-dark,
.text-bg-dark,
.card.bg-dark
.border-dark {
    background-color: #2A2A2A !important;
    color: #fff !important;
}


.btn-dark {
    background-color: #2A2A2A !important;
    border-color: #2A2A2A !important;
    color: #fff !important;
}

    .btn-dark:focus {
        background-color: #2A2A2A !important;
        border-color: #2A2A2A !important;
        color: #fff !important;
    }

.btn.btn-dark:hover:not(.btn-active) {
    background-color: #2A2A2A !important;
    border-color: #2A2A2A !important;
    color: #fff !important;
}

/*.select2-sem-pesquisa + .select2-container .select2-selection {
    height: 40px !important;    
    border-radius:  !important;
    border: 1px solid #EEEEEE !important;
}*/

.select2-sem-pesquisa {
    height: 40px !important;
    border-radius: 8px !important;
    border: 1px solid #EEEEEE !important;
}

.custom-border-radius {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.btn-salvar {
    background-color: #2a2a2a !important;
    color: #fff;
    width: 245px;
    height: calc(1.5em + 1.1rem + 1px);
    border-radius: 0.475rem;
    border: 1px solid #2A2A2A;
}

.btn-voltar {
    background-color: #fff;
    color: #2A2A2A;
    width: 245px;
    height: calc(1.5em + 1.1rem + 1px);
    border-radius: 0.475rem;
    border: 1px solid #2A2A2A;
    font-weight: bold;
}

.btn-aplicarfiltro {
    background-color: #2a2a2a !important;
    color: #fff;
    width: 245px;
    height: 40px;
    border-radius: 8px;
    border: 1px solid #2A2A2A;
}

.btn-remover-filtro {
    background-color: #fff;
    color: #2A2A2A;
    width: 245px;
    height: 40px;
    border-radius: 8px;
    border: 1px solid #2A2A2A;
    font-weight: bold;
}

.select2-selection__rendered {
    padding-right: 30px !important; /* Aumenta o espaço para o botão de limpar para os campos de select2*/
}


/* Aplica estilo a todos os links dentro de .nav-line-tabs (ou .nav-tabs) */
.nav-line-tabs .nav-link,
.nav-tabs .nav-link {
    color: #000 !important; /* Cor inicial (se quiser mudar) */
    border-bottom: none !important; /* Remove borda (se tiver) */
}

    /* Força o hover/focus a ficar vermelho */
    .nav-line-tabs .nav-link:hover,
    .nav-tabs .nav-link:hover,
    .nav-line-tabs .nav-link:focus,
    .nav-tabs .nav-link:focus {
        color: #E40520 !important; /* Texto em vermelho no hover/focus */
        border-color: #E40520 !important; /* Se tiver borda inferior, fica vermelha */
    }

    /* Para o estado ativo (clicado/selecionado) */
    .nav-line-tabs .nav-link.active,
    .nav-tabs .nav-link.active,
    .nav-line-tabs .nav-link.show,
    .nav-tabs .nav-link.show {
        color: #E40520 !important; /* Texto em vermelho ao estar ativo */
        border-bottom: 2px solid #E40520 !important; /* Linha inferior vermelha (ou ajuste conforme o layout) */
    }


tags.tagify {
    padding-left: 10px !important;
    padding-right: 10px !important;
}

/* Quando está colapsado (data-kt-app-sidebar-minimize="on") e houver .sidebar-hover,
   forçamos a sidebar a parecer expandida */
body[data-kt-app-sidebar-minimize="on"].sidebar-hover .app-sidebar {
    width: 250px !important;
    transition: width 0.2s ease;
}
/* Mostrar os textos/títulos do menu que antes ficariam ocultos */
body[data-kt-app-sidebar-minimize="on"].sidebar-hover .menu-title {
    display: inline-block !important;
}
/* Trocar a logo para a maior enquanto hover */
body[data-kt-app-sidebar-minimize="on"].sidebar-hover .logo-default {
    display: inline !important;
}

body[data-kt-app-sidebar-minimize="on"].sidebar-hover .logo-collapsed {
    display: none !important;
}


/*.skeleton {
    background-color: #e0e0e0;
    animation: pulse 1.5s infinite;
}

@keyframes pulse {
    0% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }

    100% {
        opacity: 1;
    }
}
*/

/*.skeleton {
    position: relative;
    overflow: hidden;
    background-color: #e0e0e0;
}

    .skeleton::after {
        content: "";
        position: absolute;
        top: 0;
        left: -150px;
        width: 150px;
        height: 100%;
        background: linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
        animation: shimmer 1.5s infinite;
    }

@keyframes shimmer {
    0% {
        left: -150px;
    }

    100% {
        left: 100%;
    }
}
*/
.required:after {
    color: #E40520 !important;
}

.skeleton-avatar {
    position: relative;
    overflow: hidden;
    background-color: #757575; /* cinza mais escuro */
    border-radius: 50%; /* garante formato circular */
}

    .skeleton-avatar::after {
        content: "";
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, transparent, rgba(220,220,220,0.4), transparent);
        animation: shimmer 1.5s infinite;
    }

@keyframes shimmer {
    0% {
        left: -100%;
    }

    100% {
        left: 100%;
    }
}

.min-h-40 {
    min-height: 40px !important;
}

/* Forçar cor vermelha no dia selecionado */
/* Forçar cor vermelha no dia selecionado */
.tempus-dominus-widget.light .date-container-days div:not(.no-highlight).active,
.tempus-dominus-widget.dark .date-container-days div:not(.no-highlight).active {
    background-color: #E40520 !important;
    border-color: red !important;
    color: white !important;
    box-shadow: none !important; /* Remover qualquer efeito de sombra */
}

    /* Para garantir que o hover não altere a cor */
    .tempus-dominus-widget.light .date-container-days div:not(.no-highlight).active:hover,
    .tempus-dominus-widget.dark .date-container-days div:not(.no-highlight).active:hover {
        background-color: darkred !important;
        border-color: darkred !important;
        color: white !important;
    }


.painel-alerta-absoluto {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 9999;
    max-width: 400px;
    padding: 10px;
}

.select2-selection__clear:hover {
    background-color: #E40520 !important;
}

.item-container {
    flex-shrink: 0;
}

.item-200 {
    width: 250px;
}

.item-250 {
    width: 250px;
}

.item-300 {
    width: 250px;
}

.item-350 {
    width: 320px;
}


.btn-dark:focus {
    background-color: #2a2a2a !important;
}

.btn-dark:hover {
    background-color: #2a2a2a !important;
}

.btn-check:checked + .btn.btn-dark, .btn-check:active + .btn.btn-dark, .btn.btn-dark:active:not(.btn-active), .btn.btn-dark.active, .btn.btn-dark.show, .show > .btn.btn-dark {
    background-color: #2a2a2a !important;
}

[data-bs-theme=light] {
    --bs-text-muted: #2a2a2a !important;
    --bs-dark: #2a2a2a !important;
    --bs-gray-900: #2a2a2a !important;
    --bs-text-dark: #2a2a2a !important;
}

.adjust-height-modal {
    height: 40px !important;
}
.adjust-height {
    height: 34.81px !important;
}

.adjust-height-ativo {
    height: 40px !important;
}

.customDropdownClass {
    width: 250px !important;
}

.form-check-input:checked {
    background-color: #E40520 !important;
}

.btn.btn-active-color-danger:hover:not(.btn-active) i {
    color: #E40520 !important;
}

.dt-buttons {
    gap: 8px;
}

.buttons-copy, .buttons-excel {
    gap: 8px;
    border-radius: 8px !important;
    height: 40px;
    width: 100px;
    border: 1px solid #2a2a2a !important;
    background: #f9f9f9 !important;
    color: #2a2a2a !important;
}

.clickable {
    cursor: pointer; /* Makes the hand appear */
}

.btn-dark {
}

.btn-check:checked + .btn.btn-dark,
.btn-check:active + .btn.btn-dark,
.btn.btn-dark:focus:not(.btn-active),
.btn.btn-dark:hover:not(.btn-active),
.btn.btn-dark:active:not(.btn-active),
.btn.btn-dark.active,
.btn.btn-dark.show,
.show > .btn.btn-dark {
    background-color: #2a2a2a !important;
    border-color: #2a2a2a !important;
}

.color-gray {
    color: #EBEAEA;
}

.text-custom {
    color: #7C7C7C !important;
}

.no-ellipsis {
    text-overflow: unset !important;
}

.readonly-checkbox {
    pointer-events: none;
}

.tempus-dominus-widget .toolbar {
    display: none !important;
}


.linkNovaGuia {

    cursor: pointer !important; /* opcional, pra manter aparência de clique */
}

.badge-soft-danger {
    background-color: #f8d7da;
    color: #721c24;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}