/* botões */
.btn {
  overflow: hidden;
  position: relative;
  border-radius: 4px;
  background-color: transparent;
  color: #fff;
  border: none;
}

.btn:hover {
  box-shadow: 0 7px 11px rgba(0, 0, 0, 0.26);
  background-color: var(--verde-superMu);
}

.btn:focus,
.btn-check:checked + .btn,
.btn.active,
.btn.show,
.btn:first-child:active,
:not(.btn-check) + .btn:active {
  border: none;
  background-color: var(--verde-superMu);
}

.btn::before {
  width: 10px;
  height: 200px;
  background-color: #fff;
  filter: blur(7px);
  transform: rotate(50deg);
  position: absolute;
  left: -200px;
  top: -40px;
  content: "";
}

.btn:hover::before {
  animation: sweepButtons 1s forwards linear;
}

.btn-success{
  background-color: var(--verde-superMu) !important;
}

@keyframes sweepButtons {
  0% {
    left: -105px;
  }
  100% {
    left: 500px;
  }
}

.btn.btn-dark {
  background-color: var(--btn-dark-color);
  border: 0;
}

.btn.btn-danger {
  background-color: var(--verde-superMu);
}

.btn.btn-dark:hover,
.btn.btn-dark:focus {
  border: 0;
  outline: none;
}

.btn.btn-dark:focus,
.btn.btn-dark:hover {
  background-color: var(--verde-superMu);
  color: currentColor;
}

/* Form Select */

.form-select,
select.form-control,
input.form-control,
textarea.form-control {
  color: var(--cinza-6);
  background-color: var(--bg-preto-70);
  border: 1px solid var(--cinza-1);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-select:focus,
input.form-control:focus,
select.form-control:focus,
input.form-control:focus,
textarea.form-control:focus {
  border-color: var(--verde-superMu);
  background-color: black;
  color: #fff;
  box-shadow: 0 0 0 0.25rem rgb(1 148 77 / 25%);
}

/* =========================== 
    Offcanvas backdrop 
  ========================== */
.offcanvas-backdrop {
  backdrop-filter: blur(7px);
}

/* =========================== 
    dropdown menu
  ========================== */
.dropdown-item {
  color: #fff;
}
.dropdown-item:focus,
.dropdown-item:hover {
  background-color: var(--verde-superMu);
  border-radius: 4px;
  color: #fff;
}

/* =========================== 
    Floating Labels
  ========================== */
.input-container {
  position: relative;
  margin-bottom: 20px;
  gap: 1rem;
  display: flex;
  flex-direction: column;
}

.input-container input {
  width: 100%;
  padding: 8px;
  background-color: #000;
  border: 1px solid #272727;
  transition: border-color 0.3s ease-in-out;
  color: var(--cinza-5);
}

input:focus {
  border: 1px solid var(--vermelho-6);
  color: var(--vermelho-5);
}

.input-container label.flutuante,
.input-container label {
  position: absolute;
  font-size: 0.8rem;
  top: 45%;
  left: 10px;
  transform: translateY(-50%);
  pointer-events: none;
  transition: 0.3s ease-out;
  text-indent: 1rem;
  color: var(--cinza-5);
}

/* Quando o input está focado, mova o rótulo para cima */
input[type="text"]:focus + label,
input[type="password"]:focus + label {
  width: max-content;
  padding: 0 7px;
  top: -10px;
  transform: translateY(0);
  font-size: 12px;
  color: var(--vermelho-6);
  background-color: #000;
  text-shadow: 0 0 7px var(--vermelho-5);
  text-indent: 0;
}

/* =========================== 
  Checkbox Styles
    ========================== */

.checkbox-container {
  display: flex;
  align-items: center;
  position: relative;
}

.styled-checkbox {
  appearance: none;
  width: 20px;
  height: 20px;
  background-color: #00000002;
  border: 1px solid #1b1b1b;
  border-radius: 3px;
  cursor: pointer;
  position: relative;
  z-index: 10;
  transition: 0.3s ease-in-out;
}

.styled-checkbox:focus,
.styled-checkbox:checked {
  border-color: var(--verde-superMu);
  filter: drop-shadow(0 0 7px var(--verde-superMu));
  transition: 0.3s ease-in-out;
}

.checkbox-symbol {
  position: absolute;
  left: 5px;
  top: 2px;
  color: var(--verde-superMu);
  font-size: 14px;
  visibility: hidden;
}

.styled-checkbox:checked + .checkbox-symbol {
  visibility: visible;
  animation: opacity1 0.3s forwards ease-in-out;
}

@keyframes opacity1 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* Medias queries */
@media screen and (min-width: 992px) {
  .container {
    max-width: 1100px;
  }
}

/* =========================== 
    Tables
  ========================== */
table.table,
table.table tr td {
  background-color: transparent;
  color: #fff;
  font-size: 0.8rem;
}

table.table tr th {
  color: var(--cinza-8);
  font-weight: normal;
  font-size: 0.8rem;
  background-color: var(--main-bg-color);
  border-left: 1px solid var(--cinza-0);
}

table.table tr td {
  border-left: 1px solid var(--cinza-0);
}

.table > :not(caption) > * > * {
  border-color: var(--cinza-0);
}

.table-hover > tbody > tr:hover > * {
  --bs-table-accent-bg: var(--bs-table-hover-bg);
  color: #dddddd;
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  color: #fff;
}

/* =========================== 
    Tabs
  ========================== */
.nav-tabs {
  border-bottom: 1px solid var(--cinza-0);
}

.nav-tabs .nav-link {
  border-color: var(--cinza-0);
  border-radius: 0;
  color: #fff;
  background: var(--bg-preto-80);
}

.nav-tabs .nav-item.show .nav-link,
.nav-tabs .nav-link.active {
  color: var(--cinza-9);
  background-color: var(--verde-superMu);
  border-color: var(--cinza-0);
}

.nav-tabs .nav-link:focus,
.nav-tabs .nav-link:hover {
  border-color: var(--cinza-3);
}

/* Dropdown bootstrap */
@media screen and (min-width: 992px) {
  .dropdown-menu {
    min-height: 300px;
  }
}

.dropdown-menu {
  max-width: 100%;
  width: 100%;
  background: linear-gradient(
    180deg,
    var(--bg-preto-80) 18%,
    rgba(0, 0, 0, 0) 99%
  );
  border: 0;
  outline: none;
  border-radius: 0;
  --bs-dropdown-spacer: -0.005rem;
  --bs-dropdown-border-radius: 0;
  transition: opacity 1s;
}

.dropdown-item.active,
.dropdown-item:active {
  background-color: var(--verde-superMu);
}

.dropdown-item:focus,
.dropdown-item:hover {
  background-color: var(--bg-preto-50);
  border-radius: 0;
  padding: 10px;
  text-indent: 0.5rem;
}

/* Dropdown hover mouse */
.dropdown:hover > .dropdown-menu {
  display: block;
}

.dropdown > .dropdown-toggle:active {
  /*Without this, clicking will make it sticky*/
  pointer-events: none;
}

/* Breadcrumbs */
ol.breadcrumb {
  list-style: none;
  padding: 10px;
}
ol.breadcrumb li {
  display: inline-block;
  font-size: 0.9rem;
}
ol.breadcrumb li:last-child {
  color: var(--grey-6);
  font-style: italic;
}
/* List */
.list-group-item {
  color: #ffffff;
  background-color: var(--bg-preto-20);
  border: var(--bs-list-group-border-width) solid rgb(80 80 80 / 13%);
}

.list-group-item,
.list-group-item.active,
.list-group-item-action:focus,
.list-group-item-action:hover {
  border-radius: 4px;
}

.list-group-item.active {
  border: none;
}

.list-group-item.active,
.list-group-item.active:hover {
  background-color: var(--verde-superMu);
}

.list-group-item-action:focus,
.list-group-item-action:hover {
  background-color: var(--bg-cinza-50);
  color: #fff;
}

/* Cards */
.card {
  background-color: var(--bg-preto-60);
}

.card .btn {
  background-color: var(--vermelho-5);
  border: none;
  color: #fff;
}

.card .card-footer {
  background-color: var(--bg-preto-80);
}
.card .card-body {
  min-height: 130px;
}

/* Badges float*/
.badge-float {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
}

.card-img,
.card-img-top {
  object-fit: cover;
}

/* Accordion */
.custom_accordion .accordion-button {
  background-color: var(--bg-cinza-50);
  color: #ffffff; /* Cor do texto do botão */
  border-color: var(--cinza-1);
  border-radius: 0; /* Borda arredondada */
}

.custom_accordion .accordion-item {
  background-color: var(--bg-cinza-50);
  border-color: var(--cinza-1);
}

.custom_accordion .accordion-button:hover {
  background-color: var(--vermelho-5);
}

.custom_accordion .accordion-button:focus {
  box-shadow: none;
}

.custom_accordion .accordion-button:not(.collapsed) {
  background-color: var(--bg-cinza-50);
  color: #fff;
  box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 #1e1e1e;
}

.custom_accordion .accordion-collapse {
  border: 1px solid var(--cinza-1);
  border-top: none;
}

.custom_accordion .accordion-body {
  padding: 10px 15px;
}

.custom_accordion .accordion-body .list-group .list-group-item a {
  color: #fff;
}

.custom_accordion .accordion-body .list-group .list-group-item {
  border-radius: 4px;
}

.custom_accordion .list-group-item {
  border-color: var(--cinza-1);
}

.custom_accordion .list-group-item a {
  color: #212529;
}

.custom_accordion .list-group-item a:hover {
  color: #ffffff;
}

.accordion-button::after {
  filter: invert(1);
}

.accordion-button:not(.collapsed)::after {
  filter: hue-rotate(122deg);
}
