/* Estilos para checkbox personalizado */
[type="checkbox"].filled-in.filled-custom:disabled:checked
  + span:not(.lever):after {
  background-color: rgba(2, 136, 209, 0.12);
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

[type="checkbox"].filled-in.filled-custom:checked + span:not(.lever):before {
  border-right-color: #0288d1;
  border-bottom-color: #0288d1;
}

/* Animação Figital */
#figital-animation {
  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;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 500px;
}

#figital-animation img {
  position: absolute;
  width: 100%;
  max-height: 500px;
  -o-object-fit: contain;
  object-fit: contain;
}

/* Estilos gerais */
#brand-logo {
  margin-top: 7px;
}

#my-clients {
  height: 90px !important;
}

#wrapper-content-header-right {
  margin-left: 45px;
}

/* Backgrounds */
#bg-header {
  background-image: url("/img/bg-header.svg");
  background-size: cover;
  background-repeat: no-repeat;
}

#bg-section-2 {
  background-image: url("/img/bg-section-2.svg");
  background-size: cover;
  background-repeat: no-repeat;
}

/* Controles de navegação */
#b-prev,
#b-next {
  position: relative;
  top: calc(260px + 20px);
}

#b-prev {
  left: -20px;
}

#b-next {
  left: 20px;
}

/* Seções específicas */
#how-to {
  height: 450px !important;
}

#title-clients {
  margin-top: 20px;
}

#sections-menu {
  height: 340px !important;
}

#sections-menu .indicator-item {
  background-color: rgba(158, 158, 158, 0.31);
  margin: 10px 0;
}

#sections-menu .indicator-item.active {
  background-color: #9e9e9e;
}

#sections-menu .box-slider {
  height: 340px;
}

#how-to-section .indicator-item {
  background-color: rgba(158, 158, 158, 0.31);
  margin: 10px 0;
}

#how-to-section .indicator-item.active {
  background-color: #9e9e9e;
}

#cult {
  background-image: url("/img/bg-cult.svg");
  background-position: right;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #27292f;
}

#my-integrations {
  height: 305px;
}

#my-integrations .carousel-item {
  padding: 0;
}

/* Grupos de botões */
.group-btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.group-btn .btn {
  width: 100%;
  border-radius: 0;
}

/* Cards de testemunhos */
.card-testimunial {
  border-radius: 20px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom;
}

.card-testimunial p {
  font-size: 14px;
}

.card-testimunial .section p {
  font-size: 16px;
}

.card-testimunial img {
  border: 5px solid #3b3f47;
}

.testimunial-subtitle {
  font-size: 12px;
}

/* Carrossel */
.carousel.carousel-slider .carousel-item {
  min-height: auto;
}

.box-slider {
  height: 300px;
  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;
}

.box-slider.s-400 {
  height: 400px;
}

.wrapper-controls {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  height: 0;
}

/* Espaçamentos */
.mt-40 {
  height: 25vh;
}

.mt-30 {
  height: 12.5vh;
}

.mt-20 {
  height: 6.25vh;
}

/* Estilos de texto */
h3.size-1 i {
  font-size: 20px;
}

h3.size-1 {
  margin: 0;
}

.subtitle-card {
  margin-top: 5px;
  margin-bottom: 0;
  font-size: 12px;
}

.subtitle-card-mobile {
  margin-bottom: 0;
}

.ms-15 {
  margin-left: 15px;
}

/* Cards de menu */
.card-menu {
  -webkit-transition: 0.25s;
  -o-transition: 0.25s;
  transition: 0.25s;
  width: 100%;
  cursor: pointer;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 20px;
}

.card-menu-mobile {
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 20px;
}

.card-menu.active {
  border-color: transparent;
  background-color: rgba(2, 136, 209, 0.1);
}

.card-menu.active h3 {
  color: #0288d1 !important;
}

/* Estilos de slide */
.slide-wrapper {
  border-radius: 20px;
}

.carousel-item {
  padding-left: 25px;
  padding-right: 25px;
}

/* Cabeçalho */
.box-header {
  top: 140px;
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: calc(100vh - 250px);
}

/* Dropdown */
.dropdown-content.oq-dropdown {
  border-radius: 10px;
  -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}

/* Modal de captura de lead */
.modal-lead-full {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: right;
  display: none;
  overflow-x: hidden;
  padding-bottom: 20px;
  position: fixed;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 999;
}

.modal-lead-full .modal-lead-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  height: calc(100vh - 60px);
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 20px;
  padding-right: 20px;
}

.modal-lead-full .modal-lead-box-center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

.modal-lead-full .modal-lead-box-center .container-form-lead {
  width: 300px;
}

.modal-lead-full form {
  min-width: 300px;
}

.modal-lead-full .modal-lead-header {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 60px;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  padding-left: 20px;
  padding-right: 20px;
}

/* LGPD */
.box-lgpd-modal {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  max-width: 300px;
  margin-top: 20px;
}

.box-lgpd-modal p {
  font-size: 12px;
  margin-left: 20px;
}

.mt-vh {
  margin-top: 50vh;
}

/* Banner de imagem */
.image-banner {
  background-image: url(/img/neons.svg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  height: 300px;
  width: 55%;
  background-color: #3b3f47;
}

/* Bubble de chat */
.bubble-iara {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 65px;
  height: 65px;
  background-image: url(/img/chat.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 989;
  border-radius: 100%;
  cursor: pointer;
}

/* Modal de lead */
.modal-lead {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 999;
}

.modal-lead .card-chat-wrapper {
  display: none;
}

.modal-lead .card-chat {
  width: 400px;
  height: 80vh;
  border-radius: 20px;
  overflow: hidden;
}

.modal-lead .card-chat iframe {
  width: 100%;
  height: 100%;
  border: none;
}

.modal-lead .card-chat .btn-floating {
  position: absolute;
  right: 0;
}

/* Navbar fixa personalizada */
.navbar-fixed-custom {
  z-index: 1000;
  position: fixed;
  top: 0;
  width: 100%;
  height: 65px;
  margin-top: 20px;
}

.custom-nav {
  background-color: rgba(0, 0, 0, 0.6);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  -webkit-box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  height: 65px;
  border-radius: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}

.custom-nav.darken {
  background-color: rgba(0, 0, 0, 0.5);
}

.custom-nav .content-left {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 20px;
}

.custom-nav .content-center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  min-width: 600px;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

.custom-nav .content-right {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-right: 20px;
}

.custom-nav .menu-custom {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.custom-nav .menu-custom .menu-custom-item {
  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: 100%;
  font-size: 14px;
  margin-left: 5px;
  margin-right: 5px;
  color: #fff;
  border-bottom: 4px solid transparent;
}

.custom-nav .menu-custom .menu-custom-item a {
  white-space: nowrap;
}

.custom-nav .menu-custom .menu-custom-item.active-custom {
  border-bottom-color: #fff;
}

.custom-nav.darken .menu-custom .menu-custom-item {
  color: #fff;
}

.logo {
  height: 35px;
}

/* Cabeçalho */
.wrapper-header {
  height: 800px;
  width: 100%;
  overflow: hidden;
}

.bg-video {
  width: 100vw;
  height: 800px;
  -o-object-fit: cover;
  object-fit: cover;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: -1;
}

.wrapper-header .wrapper-overlay {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 85px;
  height: 800px;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

.bg-image {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  width: 100%;
  height: 800px;
  z-index: -1;
  -o-object-fit: cover;
  object-fit: cover;
}

.flex-align-center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.custom-subtitle {
  font-size: 20px;
  margin-left: 10px;
  margin-right: 10px;
}

.custom-h1 {
  font-weight: 500;
  font-size: 50px;
  margin-left: 10px;
  margin-right: 10px;
}

.card-panel.custom-card {
  border-radius: 10px;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: 1px solid rgba(0, 0, 0, 0.3);
}

.title-card-results {
  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;
  font-size: 14px;
  font-weight: 300;
  text-align: center;
  margin: 0;
}

.title-card-results.center {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.title-card-results i {
  font-size: 16px;
  margin-right: 10px;
}

.number-card-results {
  font-size: 40px;
  line-height: 90%;
  font-weight: 500;
  text-align: center;
  margin-bottom: 10px;
  margin-top: 10px;
}

.subtitle-card-results {
  font-weight: 300;
  font-size: 12px;
  text-align: center;
  margin: 0;
}

.custom-row {
  margin-bottom: 0;
}

.custom-row .card-panel {
  min-height: 160px;
}

.videobgheader {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 800px;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-filter: opacity(70%);
  filter: opacity(70%);
}

/* Pop-up */
.container-popup {
  width: 100%;
  height: 100%;
  position: fixed;
  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;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  z-index: 1001;
  background-color: rgba(0, 0, 0, 0.6);
}

.modal-lead-popup {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  overflow-x: hidden;
  width: 1000px;
  border-radius: 20px;
}

.modal-lead-popup .modal-lead-box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 20px;
  padding-right: 20px;
}

.modal-lead-popup .modal-lead-box-center {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

.modal-lead-popup .modal-lead-box-center .container-form-lead {
  width: 300px;
}

.modal-lead-popup form {
  min-width: 300px;
}

.modal-lead-popup .modal-lead-header {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 60px;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  padding-left: 20px;
  padding-right: 20px;
}

.modal-lead-popup .custom-height-col {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  height: 400px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-left: 20px;
  background-image: url("/img/bg-capture-popup.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* Esconder controles de vídeo */
video::-webkit-media-controls-start-playback-button {
  display: none !important;
  -webkit-appearance: none;
}

/* Seção de resultados */
#vgv {
  background-image: url("/img/bg-results.png");
  background-position: bottom;
  background-size: contain;
  background-repeat: no-repeat;
}

/* Cards de planos */
.plan-card {
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  border-radius: 15px;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.2);
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  margin-bottom: 20px;
}

.plan-card:hover {
  -webkit-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  transform: translateY(-5px);
  -webkit-box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
}

.plan-header {
  padding: 30px 20px;
  color: white;
  text-align: center;
}

.plan-title {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 5px;
}

.plan-subtitle {
  font-size: 16px;
  opacity: 0.8;
}

.plan-features {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  padding: 30px;
  background-color: white;
}

.plan-features ul {
  padding-left: 0;
}

.plan-features li {
  list-style-type: none;
  margin-bottom: 15px;
  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;
  font-size: 14px;
}

.plan-features li i {
  margin-right: 10px;
  color: #27292f;
}

.plan-users {
  padding: 15px;
  text-align: center;
  font-weight: 600;
  background-color: rgba(255, 255, 255, 0.1);
  color: white;
}

.plan-cta {
  padding: 30px;
  text-align: center;
  background-color: white;
}

.btn-large {
  border-radius: 30px;
  text-transform: none;
  font-weight: 600;
  padding: 0 30px;
}

.gradient-1,
.gradient-2,
.gradient-3 {
  background: -webkit-linear-gradient(45deg, #1565c0, #64b5f6);
  background: -o-linear-gradient(45deg, #1565c0, #64b5f6);
  background: linear-gradient(45deg, #1565c0, #64b5f6);
}

/* Media Queries */
@media screen and (max-width: 800px) {
  #my-integrations {
    height: 165px;
  }

  .logo {
    height: 25px;
  }

  .videobgheader,
  .wrapper-header,
  .bg-video,
  .bg-image,
  .wrapper-header .wrapper-overlay {
    height: 87vh;
  }

  .custom-h1 {
    font-size: 30px;
  }

  .modal-lead-full .modal-lead-box {
    height: auto;
  }

  .modal-lead-full .modal-lead-box-center .container-form-lead {
    width: 90%;
  }

  .modal-lead-popup {
    width: 100%;
    height: 90%;
    margin-left: 10px;
    margin-right: 10px;
  }

  .modal-lead-popup .custom-height-col {
    height: auto;
    margin-bottom: 20px;
  }

  .modal-lead {
    right: 0;
    bottom: 0;
  }

  .modal-lead .card-chat {
    width: 100vw;
    height: 100vh;
    border-radius: 0;
  }
}

@media screen and (max-width: 1300px) {
  #my-integrations {
    height: 220px;
  }
}

@media screen and (min-width: 900px) {
  .modal-lead-full {
    overflow: hidden;
  }
}

/* Estilos para iOS */
@supports (-webkit-touch-callout: none) {
  .wrapper-header,
  .bg-video,
  .bg-image {
    height: -webkit-fill-available;
  }

  .box-header {
    height: calc(100vh - 250px);
    height: calc(-webkit-fill-available - 250px);
  }

  .modal-lead-full .modal-lead-box {
    height: calc(100vh - 60px);
    height: calc(-webkit-fill-available - 60px);
  }
}

/* Melhorias de compatibilidade para flexbox */
.flex-container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

/* Melhorias para transformações e transições */
.transform-element {
  -webkit-transform: translateY(-5px);
  -ms-transform: translateY(-5px);
  transform: translateY(-5px);
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

/* Melhorias para gradientes */
.gradient-background {
  background: -webkit-linear-gradient(45deg, #1565c0, #64b5f6);
  background: -o-linear-gradient(45deg, #1565c0, #64b5f6);
  background: linear-gradient(45deg, #1565c0, #64b5f6);
}

/* Melhorias para filtros */
.filter-element {
  -webkit-filter: opacity(70%);
  filter: opacity(70%);
}

/* Melhorias para sombras */
.box-shadow {
  -webkit-box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
}

/* Melhorias para animações */
@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.fade-in {
  -webkit-animation: fadeIn 0.5s ease-in;
  animation: fadeIn 0.5s ease-in;
}

/* Melhorias para scroll suave */
html {
  scroll-behavior: smooth;
}

@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

/* Melhorias para inputs em dispositivos móveis */
input[type="text"],
input[type="email"],
input[type="password"],
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

/* Melhorias para o backdrop-filter */
@supports (-webkit-backdrop-filter: none) or (backdrop-filter: none) {
  .backdrop-blur {
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }
}

/* Fallback para navegadores que não suportam backdrop-filter */
@supports not ((-webkit-backdrop-filter: none) or (backdrop-filter: none)) {
  .backdrop-blur {
    background-color: rgba(255, 255, 255, 0.8);
  }
}

/* Melhorias para object-fit */
.object-fit-cover {
  -o-object-fit: cover;
  object-fit: cover;
  font-family: "object-fit: cover;"; /* Polyfill para IE */
}

/* Melhorias para performance em dispositivos móveis */
@media screen and (max-width: 768px) {
  * {
    -webkit-tap-highlight-color: transparent;
  }

  .heavy-animation {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    will-change: transform;
  }
}

/* Melhorias para acessibilidade */
.visually-hidden {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/* Melhorias para impressão */
@media print {
  .no-print {
    display: none !important;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }
}

/* Correções específicas para Safari */
@media not all and (min-resolution: 0.001dpcm) {
  @supports (-webkit-appearance: none) {
    .safari-flexbox-fix {
      display: -webkit-box;
      display: flex;
    }
  }
}

/* Correções específicas para Firefox */
@-moz-document url-prefix() {
  .firefox-scrollbar {
    scrollbar-width: thin;
    scrollbar-color: #888 #f1f1f1;
  }
}

/* Correções específicas para Edge (Chromium) */
@supports (-ms-ime-align: auto) {
  .edge-fix {
    -ms-overflow-style: -ms-autohiding-scrollbar;
  }
}
