body,html{
	height: 100%;
	margin: 0;
	background: #ffffff;
}
.fullscreen-chat {
    position: auto;
    top: 10%;
    left: 10;
    
    bottom: 0;
    margin: 0;
    padding: 5%;
    width: 100%;
    height: 100%;
}
.chat{
	margin-top: auto;
	margin-bottom: auto;
}

.card {
  display: flex;
  flex-direction: column;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 1px;
  width: 80%;
  max-width: 1750px;
  height: 80vh;
  border-radius: 35px !important;
  background-color: #ffffff !important;
}


.card-login {
    position: relative;
    display: flex;
    flex-direction: column;
    max-width: 900px;
    width: 100%;
    word-wrap: break-word;
    background-color: rgb(255, 255, 255);
    background-clip: border-box;
    border: 1px solid #e3e6f0;
    border-radius: .35rem
}


.logo-img {
    width: 150px;
    height: auto;
    margin-bottom: 20px;
    display: block;
    margin-left: auto;
    margin-right: auto;
}


.contacts_body{
	padding:  0.75rem 0 !important;
	overflow-y: auto;
	white-space: nowrap;
}

.msg_card_body {
  flex: 1 1 auto;
  overflow-y: auto;
}

.card-header{
	border-radius: 15px 15px 0 0 !important;
	border-bottom: 0 !important;
}

.card-footer {
  border-radius: 0 0 15px 15px !important;
  border-top: 0 !important;
}

.container{
	align-content: center;
}
.search{
	border-radius: 15px 0 0 15px !important;
	background-color: rgba(0,0,0,0.3) !important;
	border:0 !important;
	color:white !important;
}
.search:focus{
	 box-shadow:none !important;
   outline:0px !important;
}
.type_msg{
	background-color: rgba(0,0,0,0.3) !important;
	border:0 !important;
	color:white !important;
	height: 60px !important;
	overflow-y: auto;
}
	.type_msg:focus{
	 box-shadow:none !important;
   outline:0px !important;
}
.attach_btn{
	border-radius: 15px 0 0 15px !important;
	background-color: rgba(0,0,0,0.3) !important;
	border:0 !important;
	color: white !important;
	cursor: pointer;
}

.send-icon {
    width: 20px;  /* Ajuste conforme o tamanho desejado */
    height: 20px;
    object-fit: contain;
  }  

.send_btn{
	border-radius: 0 15px 15px 0 !important;
	background-color: rgba(0,0,0,0.3) !important;
	border:0 !important;
	color: white !important;
	cursor: pointer;
}
.search_btn{
	border-radius: 0 15px 15px 0 !important;
	background-color: rgba(0,0,0,0.3) !important;
	border:0 !important;
	color: white !important;
	cursor: pointer;
}
.contacts{
	list-style: none;
	padding: 0;
}
.contacts li{
	width: 100% !important;
	padding: 5px 10px;
	margin-bottom: 15px !important;
}
.active{
	background-color: rgba(0,0,0,0.3);
}
.user_img{
	height: 70px;
	width: 70px;
	border:1.5px solid #f5f6fa;

}
.user_img_msg{
	height: 40px;
	width: 40px;
	border:1.5px solid #f5f6fa;

}
.img_cont{
	position: relative;
	height: 70px;
	width: 70px;
}
.img_cont_msg{
	height: 40px;
	width: 40px;
}
.online_icon{
	position: absolute;
	height: 15px;
	width:15px;
	background-color: #4cd137;
	border-radius: 50%;
	bottom: 0.2em;
	right: 0.4em;
	border:1.5px solid white;
}
.offline{
	background-color: #c23616 !important;
}
.user_info{
	margin-top: auto;
	margin-bottom: auto;
	margin-left: 15px;
}
.user_info span{
	font-size: 20px;
	color: #3a3b45;
}
.user_info p{
	font-size: 10px;
	color: #3a3b45;
}
.video_cam{
	margin-left: 50px;
	margin-top: 5px;
}
.video_cam span{
	color: white;
	font-size: 20px;
	cursor: pointer;
	margin-right: 20px;
}
.msg_cotainer{
	margin-top: auto;
	margin-bottom: auto;
	margin-left: 10px;
	border-radius: 25px;
	background-color: #858796;
	padding: 10px;
	position: relative;
}
.msg_cotainer_send{
	margin-top: auto;
	margin-bottom: auto;
	margin-right: 10px;
	border-radius: 25px;
	background-color: #414141;
	padding: 10px;
	position: relative;
}
.msg_time{
	position: absolute;
	left: 0;
	bottom: -15px;
	color: rgb(170, 170, 170);
	font-size: 10px;
}
.msg_time_send{
	position: absolute;
	right:0;
	bottom: -15px;
	color: rgb(170, 170, 170);
	font-size: 10px;
}
.msg_head{
	position: relative;
}
#action_menu_btn{
	position: absolute;
	right: 10px;
	top: 10px;
	color: white;
	cursor: pointer;
	font-size: 20px;
}
.action_menu{
	z-index: 1;
	position: absolute;
	padding: 15px 0;
	background-color: rgba(0,0,0,0.5);
	color: white;
	border-radius: 15px;
	top: 30px;
	right: 15px;
	display: none;
}
.action_menu ul{
	list-style: none;
	padding: 0;
	margin: 0;
}
.action_menu ul li{
	width: 100%;
	padding: 10px 15px;
	margin-bottom: 5px;
}
.action_menu ul li i{
	padding-right: 10px;
}
.action_menu ul li:hover{
	cursor: pointer;
	background-color: rgba(0,0,0,0.2);
}
@media(max-width: 576px){
	.contacts_card{
	margin-bottom: 15px !important;
}
}


.loader {
	border: 4px solid #f3f3f3;
	border-radius: 50%;
	border-top: 8px solid black;
	width: 30px;
	height: 30px;
	-webkit-animation: spin 2s linear infinite; /* Safari */
	animation: spin 2s linear infinite;
	display: none;
  }

  .loading{
	margin: auto;
	width: 100%;
	display: flex;
	justify-content: center;
  }
  

  body {
    background-color: white;  /* Fundo verde */
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    margin: 0;
    font-family: Arial, sans-serif;
    color: white;
}



  .body-chat {
    background-color: #858796;  /* Fundo verde */
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    margin: 0;
    font-family: Arial, sans-serif;
    color: white;
}

.container-login {
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}


.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl {
    max-width: 100%;
    height: 100%;
    width: 100%;
    padding-right: .75rem;
    padding-left: .75rem;
    margin-right: auto;
    margin-left: auto
}

/* Tamanho padrão para telas grandes */
.container-upload,
.container-fluid-upload,
.container-lg-upload,
.container-md-upload,
.container-sm-upload,
.container-xl-upload {
    width: auto; /* Ajusta a largura para telas médias */
    height: auto; /* Altura proporcionalmente reduzida */
    
}

.upload-button {
    outline: none; /* Remove o contorno padrão ao clicar ou focar no botão */
    box-shadow: none; /* Remove qualquer sombra de contorno padrão ao clicar ou focar no botão */
}

.fixed-button-container {
    position: fixed; 
    top: 10px; 
    right: 10px; 
    /*background-color: white;  */
    padding: 10px; 
    border-radius: 5px; 
    /*box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);  */
    z-index: 1000;
}


.button-container {
	text-align: center;
    margin-top: 20px;
}

.button-agent {
	text-align: center;
    margin-top: 10px;
}

.button-agent span {
    font-size: 14px;
    color: #3a3b45;
    display: block; /* Adiciona isso para garantir que o <span> ocupe toda a linha */
    margin-bottom: 10px; /* Adiciona espaço entre o <span> e os botões */
}

.btn {
    background-color: #011E41;
    color: white;
    padding: 10px 20px;
    margin: 10px;
    text-decoration: none;
    border-radius: 5px;
    font-size: 16px;
    transition: background-color 0.3s;
}

.btn:hover {
    background-color: #041e50
}

.btn-xlsx {
    background: url('/static/img/download.png') no-repeat center;
    background-size: contain;
    width: 1.25em;
    height: 1.25em;
    border: none;
    padding: 0;
    background-color: transparent;
}

.btn-xlsx:hover {
    background-image: url('/static/img/download-color.png');
}

.btn-xlsx:focus {
    outline: none;
}

.btn-lamp {
    background: url('/static/img/light-bulb-no-color.png') no-repeat center;
    background-size: contain;
    width: 1.25em;
    height: 1.25em;
    border: none;
    padding: 0;
    background-color: transparent;
}

.btn-lamp:hover {
    background-image: url('/static/img/light-bulb-color.png');
}

.btn-lamp:focus {
    outline: none;
}

.btn-star {
    background: url('/static/img/star.png') no-repeat center;
    background-size: contain;
    width: 1.25em;
    height: 1.25em;
    border: none;
    padding: 0;
    background-color: transparent;
}

.btn-star:hover {
    background-image: url('/static/img/star-color.png');
}

.btn-star:focus {
    outline: none;
}

.horizontal-space {
    width: 350px; 
    display: inline-block;
}
.card-container {
    background-color: #ffffff;  
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 0 0 0.2rem rgba(78, 115, 223, 0.25);
    text-align: center;
    color: rgb(0, 0, 0);
}


/* Estilo do botão desabilitado */
.btn-index-disabled {
    background-color: #858796; /* Cor do botão desabilitado */
    color: white; /* Cor do texto do botão */
    padding: 10px 20px; 
    margin: 10px; 
    text-decoration: none;
    border-radius: 5px; 
    font-size: 16px; 
    transition: background-color 0.3s, color 0.3s; 
    border: none; 
    box-shadow: none; 
    outline: none; 
}

/* Estilo de hover quando o botão estiver desabilitado */
.btn-index-disabled:hover {
    background-color: #ff4d4d; /* Cor de fundo vermelha no hover */
    color: white; /* Cor do texto no hover */
}

/* Estilo do botão habilitado (se quiser adicionar) */
.btn-index-enabled {
    background-color: #858796; /* Cor de fundo do botão habilitado */
    color: white;
    padding: 10px 20px; 
    margin: 10px; 
    text-decoration: none;
    border-radius: 5px; 
    font-size: 16px; 
    transition: background-color 0.3s, color 0.3s; 
    border: none; 
    box-shadow: none; 
    outline: none; 
}

/* Estilo de hover quando o botão estiver habilitado */
.btn-index-enabled:hover {
    background-color: #041e50; /* Cor de fundo no hover do botão habilitado */
    color: white;
}


.btn-file {
    background-color: #858796; 
    color: white; 
    padding: 10px 20px; 
    margin: 10px; 
    text-decoration: none;
    border-radius: 5px; 
    font-size: 16px; 
    transition: background-color 0.3s, color 0.3s; 
    border: none; 
    box-shadow: none; 
    outline: none; 
}

.btn-file:hover {
    background-color: #041e50; 
    color: white; 
}


.btn-chat {
    background-color: #858796;
    color: white;
    padding: 10px 20px;
    margin: 10px;
    text-decoration: none;
    border-radius: 5px;
    font-size: 16px;
    transition: background-color 0.3s, color 0.3s;
}

.btn-chat:hover {
    background-color: #041e50;
    color: white;
}

.btn-agent {
    padding: 10px 20px;
    text-decoration: none;
    background-color: #f0f0f0;
    color: #000;
    border: 1px solid #ccc;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.btn-agent:hover {
    background-color: #041e50;
    color: white;
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -.75rem;
    margin-left: -.75rem
}



.justify-content-center {
    justify-content: center !important
}

.o-hidden {
    overflow: hidden !important
}

.border-0 {
    border: 0 !important
}

.shadow-lg {
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, .175) !important
}

.mb-4,
.my-4 {
    margin-bottom: 1.5rem !important
}

.mb-5,
.my-5 {
    margin-bottom: 3rem !important
}

.mt-1,
.my-1 {
    margin-top: .25rem !important
}

.col,
.col-1,
.col-10,
.col-11,
.col-12,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-auto,
.col-lg,
.col-lg-1,
.col-lg-10,
.col-lg-11,
.col-lg-12,
.col-lg-2,
.col-lg-3,
.col-lg-4,
.col-lg-5,
.col-lg-6,
.col-lg-7,
.col-lg-8,
.col-lg-9,
.col-lg-auto,
.col-md,
.col-md-1,
.col-md-10,
.col-md-11,
.col-md-12,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-auto,
.col-sm,
.col-sm-1,
.col-sm-10,
.col-sm-11,
.col-sm-12,
.col-sm-2,
.col-sm-3,
.col-sm-4,
.col-sm-5,
.col-sm-6,
.col-sm-7,
.col-sm-8,
.col-sm-9,
.col-sm-auto,
.col-xl,
.col-xl-1,
.col-xl-10,
.col-xl-11,
.col-xl-12,
.col-xl-2,
.col-xl-3,
.col-xl-4,
.col-xl-5,
.col-xl-6,
.col-xl-7,
.col-xl-8,
.col-xl-9,
.col-xl-auto {
    position: relative;
    width: 100%;
    padding-right: .75rem;
    padding-left: .75rem
}

.d-none {
    display: none !important
}

.d-lg-block {
	display: block !important
}

.p-5 {
    padding: 3rem !important
}

.text-center {
    text-align: center !important
}

.img-fluid {
    width: 100%;
    height: auto;
    max-width: 100%; /* Ajuste conforme necessário */
}

.img-upload {
    width: 50%;
    height: 20%;
    max-width: 100%; /* Ajuste conforme necessário */
}

.text-gray-900 {
    color: #3a3b45 !important
}


.welcome-title {
    font-size: 1.75rem;
    font-weight: bold;
    color: #343a40;
    margin-bottom: 30px;
}



.btn-login {
    display: inline-block;
    font-weight: 400;
    color: #7C7C7C;
    text-align: center;
    vertical-align: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: .375rem .75rem;
    font-size: 1rem;
    text-decoration: none;
    line-height: 1.5;
    width: 100%;
    border-radius: .35rem;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

.btn-secondary {
    color: #fff;
    background-color: #858796;
    border-color: #858796;
}


form.user .btn-user {
    font-size: .8rem;
    border-radius: 10rem;
    padding: .75rem 1rem;
    max-width: 100px;
    margin: 0 auto;
}

.card>hr {
    margin-right: 0;
    margin-left: 0
}

#thoughtModalBody {
    color: #414141;
}

#thoughtModalLabel {
    color: #414141; /* Cor do texto no título do modal */
    font-size: 1.5rem; /* Tamanho da fonte */
    font-weight: bold; /* Peso da fonte */
    text-align: center; /* Alinhamento do texto */
    margin-bottom: 1rem; /* Margem inferior */
}

#thoughtModalBody {
    color: #414141;
}
.typing-message {
    font-style: italic;
    color: white;
}

.typing-dots::after {
    content: '';
    display: inline-block;
    width: 1em;
    text-align: left;
    animation: dots 1s steps(4, end) infinite;
}

@keyframes dots {
    0%, 100% {
        content: '...';
    }
    25% {
        content: '.';
    }
}

.lightbulb-icon {
    vertical-align: middle; /* Alinhar verticalmente ao texto */
    margin-right: 5px; /* Margem à direita para separação do texto */

}


.card-txt {
    border-radius: 8px;
}

.card-txt-body p {
    font-weight: 500;
}

.list-group-item:hover {
    background-color: #f8f9fa;
    cursor: pointer;
}

.list-group-item i {
    transition: color 0.2s ease;
}

.list-group-item:hover i {
    color: #0056b3;
}

/* Estilos para mensagens de sucesso e erro */
.alert-success {
    color: white;
    background-color: #006400; /* Verde escuro */
    border: 1px solid #004d00;
    padding: 10px;
    margin-bottom: 15px;
    border-radius: 5px;
}

.alert-error {
    color: white;
    background-color: #8B0000; /* Vermelho escuro */
    border: 1px solid #600000;
    padding: 10px;
    margin-bottom: 15px;
    border-radius: 5px;
}


@font-face {
    font-family: 'ElectroluxSans';
    src: url('/static/fonte/ElectroluxSans_2_Light.otf') format('opentype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'ElectroluxSans';
    src: url('/static/fonte/ElectroluxSans_3_Regular.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'ElectroluxSans';
    src: url('/static/fonte/ElectroluxSans_4_Semibold.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'ElectroluxSans';
    src: url('/static/fonte/ElectroluxSans_5_Bold.otf') format('opentype');
    font-weight: 700;
    font-style: normal;
}

/* Para textos normais */
body {
    font-family: 'ElectroluxSans', sans-serif;
    font-weight: 400;
}

/* Para texto leve */
.light-text {
    font-weight: 300;
    
}

/* Para semi-negrito */
.semibold-text {
    font-weight: 600;
}

/* Para negrito */
.bold-text {
    font-weight: 700;
}


.markdown-style h3 {
    font-size: 1.25rem;
    margin-top: 1rem;
    font-weight: bold;
}

.markdown-style ul {
    padding-left: 1.2rem;
    margin-bottom: 1rem;
}

.markdown-style li {
    margin-bottom: 0.5rem;
}

.markdown-style code {
    background-color: #f5f5f5;
    padding: 2px 4px;
    border-radius: 4px;
    font-family: monospace;
}.markdown-style h3 {
    font-size: 1.25rem;
    margin-top: 1rem;
    font-weight: bold;
}

.markdown-style ul {
    padding-left: 1.2rem;
    margin-bottom: 1rem;
}

.markdown-style li {
    margin-bottom: 0.5rem;
}

.markdown-style code {
    background-color: #f5f5f5;
    padding: 2px 4px;
    border-radius: 4px;
    font-family: monospace;
}

  /* Safari */
  @-webkit-keyframes spin {
	0% { -webkit-transform: rotate(0deg); }
	100% { -webkit-transform: rotate(360deg); }
  }
  
  @keyframes spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
  }