@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap');
html, body {
    height: 100%;
    margin: 0;
    font-family:"Inter", serif !important;
    overflow-y: hidden; /* Adicionado para ocultar a parte inferior */
    overflow-x: hidden; /* Adicionado para ocultar a parte inferior */
    background-color: #f4f6f8;
}

.grecaptcha-badge {
  visibility: hidden;
}

.style-action{
    padding-top: 1px;
    padding-bottom: 1px;
    padding-left: 7px;
    padding-right: 7px
}

.button-voltar{
    height: 23px;
    padding-top: 0px;
    margin-right: 15px
}

.user-panel.mt-3.pb-3.mb-3.d-flex.imagem-lateral {
    margin: 0 !important;
}

.user-panel.mt-3.pb-3.mb-3.d-flex.imagem-lateral img {
    width: auto;
    height: 40px;
}

.sidebar-collapse .user-panel.mt-3.pb-3.mb-3.d-flex.imagem-lateral img{
    padding-left: 16px;
}

.sidebar.os-host.os-theme-light.os-host-resize-disabled.os-host-scrollbar-horizontal-hidden.os-host-scrollbar-vertical-hidden.os-host-transition {
    margin: 10px 0;
}
.background-container {
  position: absolute;
  top: 0;
  left: -50%; 
  width: 150%; 
  height: 100vh; 
  background-image: url("../img/bg.webp");
  background-position: center; 
  background-repeat: no-repeat;
  background-size: cover; 
  filter: brightness(50%) contrast(90%);
  z-index: -2;
  opacity: 1;
}

.card {
  position: relative;
  /* Para que o z-index do .login-box funcione */
  z-index: 1;
  /* Fica na frente do background-container */
}

.container-login {
  display: flex;
}

.container-fluid {
  height: 100vh;
  /* display: flex; */
  align-items: stretch;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.welcome-section {
  background-color: #1b1f24;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding: 0;
  position: relative;
  width: auto;
  height: auto;
  overflow: hidden;
  z-index: 1;
}

.text-logo {
  margin-bottom: 0 !important;
  text-align: center;
  
}

  
  .div-texto{
    margin-bottom: -40px; /* Espaço entre o texto e a borda inferior */
    color: #98989e;
    font-weight: bold;
    font-size: 14px;
  }
.welcome-section h2 {
    font-weight: bold;
    font-size: 2.5rem;
}
.welcome-section p {
    font-size: 1.2rem;
    margin-top: 1rem;
}
.center-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-grow: 1;
    padding-left: 20px;
    width: 100%; 
    height: auto;
   
}
.center-content .text-center {
    width: 100%; 
}

.center-content .text-center h2 {
    color: #fff;
    font-size: 3rem;
    text-align: left;
    margin-left: 30px;
    line-height: 1.2;
    margin-bottom: 120px; 
}
  
  .center-content .text-center h2 .normal {
    font-weight: 400; 
  }
  
  .center-content .text-center h2 .bold {
    font-weight: 700; 
  }

.logo {
    width: 150px;
    margin-bottom: 2.5rem;
}
.contact-info{
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-left: 18px;
}
.contact-info p {
    font-weight: 500;
    line-height: 1.5;
    color: #fff;
    margin-bottom: 5px;
    font-size: clamp(0.875rem, 0.5vw, 1rem);
    display: flex; 
    flex-wrap: wrap; 
    align-items: center; 
  }
  .contact-info p i {
    margin-right: 5px; /* Espaço entre o ícone e o texto */
}
.contact-info .whatsapp-group,
.contact-info .email-group {
    display: flex; /* Torna os grupos flex containers */
    align-items: center; /* Alinha os ícones verticalmente ao centro */
    margin-right: 15px; /* Espaço entre os grupos */
    white-space: nowrap; /* Evita a quebra de linha dentro do grupo*/
}
.login-box {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 20px;
  z-index: 0;
}

.btn-lg {
        padding: 0.5rem 1rem; 
        font-size: 1.25rem; 
        line-height: 1.5;
        border-radius: 0.3rem;
}
.btn-lg:hover{
    box-shadow: rgba(28, 28, 152, 0.198) 0px 4px 12px, rgba(43, 43, 156, 0.198) 0px 8px 20px, rgba(39, 39, 162, 0.207) 0px 16px 56px;
    transition: 200ms;
}

/* whatsap */

.whatsapp-button {
position: fixed; 
bottom: 20px; 
right: 20px; 
background-color: #25d366;
color: #fff;
padding: 10px; 
border-radius: 50%; 
text-decoration: none;
box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.25);
z-index: 1000; 
display: flex;
align-items: center; 
justify-content: center;
}

.whatsapp-button:hover {
background-color: #128c7e; 
box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.3); 
}


/* icons */
.fa-envelope, .fa-lock {
    font-size: 1rem !important; 
}
.fa-mobile-phone,.fa-certificate{
    font-size: 1.8rem !important; 
}
.whatsapp-button{
  font-size: clamp(1rem, 4vw, 1.2rem);
}
.whatsapp-group .fa-whatsapp{
  font-size: clamp(1.1rem, 4vw, 1.1rem);
}
/*Formulario de login e senha */
.form-label {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
    color: #2a2a2a;
    font-weight: 500!important; 
    font-size: 1rem;
}
.texto-vazado {
    background-color: #9a9a9f; 
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    font-size: 0.875rem;
  }

.custom-input-wrapper {
    display: flex; 
    align-items: center; 
    border: 1px solid #dedede;
    border-radius: 25px;
    padding: 0.3rem; 
    background-color: #fff; 
}

.custom-input-wrapper .icon {
    color: #afafb3; 
    margin-right: 8px; 
    padding-left: 8px; 
    font-size: 1.2rem;
}

.custom-input-wrapper .custom-input {
    border: none; 
    flex-grow: 1; 
    background-color: transparent; 
    font-size: 1rem; 
    outline: none; 
    color: #495057; 
    padding: 0; 
}

.custom-input-wrapper .custom-input:focus {
    box-shadow: none; 
    outline: none;
}

.custom-input-wrapper:focus-within {
    border-color:#8fbcff;
}
/* Quadrado laranja */

.orange-curve {
    position: absolute;
    bottom: -6%; 
    right: -6%; 
    width: 16vw; 
    height: 20vh; 
    border: 3px solid #c85321;
    background-color: transparent;
    z-index: 0;
    border-radius: 50px;
}

.orange-curve2 {
    position: absolute;
    bottom: 87%; 
    right: 75%; 
    width: 16vw; 
    height: 20vh; 
    border: 3px solid #c85321;
    background-color: transparent;
    z-index: 0;
    border-radius: 50px;
}
/*remover borda de preenchimento automatico*/
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px white inset !important;
}
.form-control {
  border: 1px solid transparent !important;
}
/* ==========================================================================
   Responsividade (Media Queries)
   ========================================================================== */

/* Tablets em modo paisagem e desktops pequenos */
@media (min-width: 769px) and (max-width: 1199px) {
  .orange-curve {
    width: 40vw;
    height: 21vh;
    bottom: -8%;
    right: -45%;
  }

  .contact-info p {
    margin-bottom: 5px;
    margin-right: 150px;
    font-size: clamp(0.675rem, 0.5vw, 0.8rem); /* Adjusted clamp values */
  }

  .center-content .text-center h2 {
    color: #fff;
    font-size: clamp(2rem, 2vw, 3rem);
    text-align: left;
    margin-left: 30px;
    line-height: 1.2;
    margin-bottom: 120px;
  }
}

/* Dispositivos extra pequenos (telefones em modo retrato) */
@media (max-width: 768px) {
  .welcome-section {
    display: none;
  }

  .container-fluid {
    display: block;
  }

  .login-logo span,
  .contact-info p {
    font-size: 0.8rem;
  }

  .orange-curve,
  .diagonal-box {
    display: none;
  }

  .center-content .text-center h2 {
    font-size: 1.6rem;
  }

  .center-content .text-center p {
    font-size: 1.4rem;
  }

  /* Background adjustments for smaller screens */
  .background-container {
    background-size: cover; /* Ensure cover is maintained */
    background-position: center; /* Keep the center focused */
  }
}

@media (min-width: 768px) {
  .login-box .card {
    width: 50%;
    max-width: none;
  }
}

/* Added for larger screens (optional) */
@media (min-width: 1200px) {
    .background-container {
        background-size: cover; /* or contain, depending on your preference */
    }
}
