input:focus { border-color: black !important; box-shadow: none !important; }
select:focus { border-color: black !important; box-shadow: none !important; }
textarea:focus { border-color: black !important; box-shadow: none !important; }
button:focus { box-shadow: none !important; }

input:nth-of-type(checkbox) { background-color: #e8f0fe !important; }
select { background-color: #e8f0fe !important; }
textarea { background-color: #e8f0fe !important; }
label::after { position: relative !important; }

.login-card {
    background: rgba(255, 255, 255, 0.1); /* Transparência */
    backdrop-filter: blur(15px); /* Efeito de vidro fosco */
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 40px;
    border-radius: 30px;
    max-width: 350px;
    margin: 16px;
    text-align: center;
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}

.input-group2 {
    text-align: left;
    margin-bottom: 20px;
    border-bottom: 1.5px solid rgba(255, 255, 255, 0.5);
}

.input-group2 label {
    display: block;
    color: #ddd;
    font-size: 14px;
    margin-bottom: 8px;
    margin-left: 5px;
}

.input-group2 input {
    width: 100%;
    padding: 12px 15px;
    background: transparent;
    border: none;
    color: white !important;
    outline: none;
}

.options {
    display: flex;
    justify-content: space-between;
    color: #ccc;
    font-size: 12px;
}

.forgot-pass {
    color: #ccc;
    text-decoration: none;
    font-style: italic;
    cursor: pointer;
}

.btn-login {
    width: 100%;
    padding: 15px;
    border: none;
    border-radius: 12px;
    color: white;
    font-weight: bold;
    font-size: 16px;
    cursor: pointer;
    transition: transform 0.2s, opacity 0.2s;
    margin-bottom: 20px;
}

.btn-login:hover {
    opacity: 0.9;
    transform: scale(1.02);
}

.input-modal {
    display: flex;
    flex-direction: column;
    border-bottom: 1px solid #ffffff80;
}

.input-modal label {
    text-align: start;
    color: #ddd;
    font-size: 14px;
}

.input-modal input {
    width: 100%;
    padding: 0px;
    margin-bottom: 5px;
    background: transparent;
    border: none;
    color: white;
    outline: none;
}

.bg-vs-code { background-color: #01102b !important; }

.h-100vh { height: 100vh !important; }

.w-100vw { width: 100vw !important; }

.bg-ccc { background-color: #CCC !important; }

.bg-e9 { background-color: #e9ecef !important; }

.bg-f2 { background-color: #f2f2f2 !important; }

.right-14 { right: 14px; }

.item-menu-cliente:hover div { 
    background-color: white !important; 
    color: #000 !important;
    border-radius: 20px;
}

.item-menu:hover div { background-color: white !important; }

.item-menu:hover div #leao { display: none; }

.item-menu:hover div #leaoHover { display: block !important; }

.logout-hover:hover { color: red !important; }

.logout-hover-admin:hover .img { display: none !important; }
.logout-hover-admin:hover .imgHover { display: block !important; }

.border-radius-25rem { border-radius: 0.25rem !important; }

.border-radius-375rem { border-radius: 0.375rem !important; }

.border-radius-50rem { border-radius: 0.50rem !important; }

.border-radius-75rem { border-radius: 0.75rem !important; }

.end-58 { right: 58px; }

.end-8 { right: 8px; }

.top-8 { top: 8px; }

.top-22 { top: 22px; }

.border-1 { border: 1px solid black; }

.irpf-selected {
    background-color: #1351b4;
    color: white !important;
    border-radius: 20px;
}

.irpf-item { color: #1351b4; }

.irpf-item:hover { 
    background-color: #dee5f3 !important; 
    border-radius: 20px;
}

.dados-card {
    display: flex;
    flex-direction: column;
    font-size: 12px;
    padding: 8px;
    background-color: rgba(0, 0, 0, 0.03);
    border-right: 1px solid rgba(0, 0, 0, 0.125);
    border-bottom: 1px solid rgba(0, 0, 0, 0.125);
    border-radius: 0.25rem;
}

.text-primary-mod { color: #1351b4 !important; }

.bg-primary-mod { background-color: #1351b4 !important; }

.h5-pc { 
    font-size: 20px !important; 
    padding-right: 24px;
    padding-left: 24px;
}

.span-pc { font-size: 16px !important; }

.h5-mobile { font-size: 16px !important; }

.span-mobile { font-size: 12px !important; }

.btn-outline-ccc {
    --bs-btn-color: #000;
    --bs-btn-border-color: #ccc;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #ccc;
    --bs-btn-hover-border-color: #ccc;
    --bs-btn-focus-shadow-rgb: 108, 117, 125;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #ccc;
    --bs-btn-active-border-color: #ccc;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #ccc;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #ccc;
    --bs-gradient: none;
}

.border-ccc { border: 1px solid #ccc !important; }

.btn-outline-sec {
    --bs-btn-color: #000;
    --bs-btn-border-color: #e2e3e5;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #e2e3e5;
    --bs-btn-hover-border-color: #e2e3e5;
    --bs-btn-focus-shadow-rgb: 108, 117, 125;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #e2e3e5;
    --bs-btn-active-border-color: #e2e3e5;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #e2e3e5;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #e2e3e5;
    --bs-gradient: none;
}

.h-83 { height: 83% !important; }

.box-shadow-999 { box-shadow: 0px 0px 8px 1px #999 !important; }

.menu {
    width: 60px;
    height: 42px;
    cursor: pointer;
}

.hamburguer {
    position: relative;
    display: block;
    background: #ffffff80;
    width: 40px;
    height: 2px;
    top: 20px;
    left: 10px;
    transition: 0.5s ease-in-out;
}

.hamburguer:before,
.hamburguer:after {
    background: #ffffff80;
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    transition: 0.5s ease-in-out;
}

.hamburguer:before {
    top: -10px;
}

.hamburguer:after {
    bottom: -10px;
}

input:checked ~ label .hamburguer {
    transform: rotate(45deg);
}

input:checked ~ label .hamburguer:before {
    transform: rotate(90deg);
    top: 0;
}

input:checked ~ label .hamburguer:after {
    transform: rotate(90deg);
    bottom: 0;
}

.page {
    background: rgba(255, 255, 255, 0.1); /* Transparência */
    backdrop-filter: blur(15px); /* Efeito de vidro fosco */
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    margin: 16px;
    padding: 16px;
    border-radius: 0.375rem;
    width: 1280px;
    max-width: 1280px;
    height: calc(100vh - 32px);
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37);
}

.logout-hover:hover img:nth-child(1) { display: none !important; }
.logout-hover:hover img:nth-child(2) { display: block !important; }

.usuario-hover:hover img:nth-child(1) { display: none !important; }
.usuario-hover:hover img:nth-child(2) { display: block !important; }

.text-f46673 { color: #f46673 !important; }
.text-6fc69e { color: #6fc69e !important; }

.tabela-fixa-wrapper {
    overflow-y: auto; 
    border-radius: 0.375rem; 
}

.tabela-fixa-wrapper thead th {
    position: sticky;
    top: 0; 
    z-index: 10; 
    width: 30%;
}

.tabela-fixa-wrapper tfoot {
    position: sticky;
    bottom: -1px; 
    z-index: 10;
}

/* Ajuste nos botões para não estourarem */
.btn-scroll {
    transform: translateY(-50%);
    width: 20px;  /* Reduzi um pouco */
    height: 20px; /* Reduzi um pouco */
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid #ddd;
    border-radius: 50%;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px; /* Seta menor */
}

.tr-hover:hover td {
    background-color: #1351b4 !important;
    color: white !important;
    cursor: pointer;
}

/* Container Externo Vertical */
.ts-vertical-container {
    display: inline-block;
    /* padding: 4px; */
    background-color: #f1f3f5;
    border-radius: 20px; /* Menos arredondado nas laterais, mais nos cantos */
    border: 1px solid #dee2e6;
}

.ts-vertical-inner {
    display: flex;
    flex-direction: column; /* EMPILHAMENTO */
    position: relative;
    width: 50px; /* Largura fixa */
    height: 100px; /* Altura total para as 3 opções */
}

.ts-v-input {
    display: none !important;
}

.ts-v-label {
    flex: 1;
    z-index: 2;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    display: flex;
    align-items: center; /* Centraliza texto verticalmente */
    justify-content: center; /* Centraliza texto horizontalmente */
    color: #6c757d;
    margin-bottom: 0;
    transition: color 0.2s ease;
}

/* O Slider que desliza para cima e para baixo */
.ts-v-slider {
    position: absolute;
    height: 33.33%; /* Um terço da altura total */
    width: 100%;
    background-color: #ffffff;
    border-radius: 15px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    z-index: 1;
    top: 0;
}

/* Lógica de Movimento Vertical */
#tsMiddle:checked ~ .ts-v-slider { transform: translateY(100%); }
#tsBottom:checked ~ .ts-v-slider { transform: translateY(200%); }

/* Cores de Ativação */
#tsTop:checked ~ label[for="tsTop"],
#tsMiddle:checked ~ label[for="tsMiddle"],
#tsBottom:checked ~ label[for="tsBottom"] {
    color: #0d6efd;
    font-weight: bold;
}