@font-face {
font-family: password;
src: url('fonts/password.ttf') format('truetype');
}
@font-face {
font-family: Lato;
src: url('fonts/Lato-Regular.ttf') format('truetype');
}
@font-face {
font-family: Courgette;
src: url('fonts/Courgette-Regular.ttf') format('truetype');
}
body, html {
            margin: 0;
            padding: 0;
            width: 100%;
            height: 100%;
            overflow: hidden;
font-family:Lato, Arial, sans-serif;min-height: 100%;
background-color: #fff; 
position:relative;
        }
		body.modal-open {
		width:100vw!important;max-width:100vw!important;
		}
		body > .container{
position: relative;
      z-index: 1;
		}		
.modal.fade .modal-dialog {
}
.modal-open {
  overflow: hidden;
  padding-right: 17px; /* Vagy ami a görgetősáv szélessége a böngésződben */
}
.modal {
  z-index: 1050 !important; /* Maradjon az alapértelmezett érték */
}
.modal-backdrop {
    z-index: 1040 !important; /* Háttér */
}
.modal-header{background-color:#514EF9;color: #fff!important;}
h5.modal-title, .modal-header button.btn-close{color: #fff!important;font-weight:700}
.btn-close {
  opacity: 1;
  background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
}
body .loadcontent{transition: all 0.3s ease;
position:fixed;z-index:999999;background-color:#eee;width:100%;height:100%;
background-size:20vw auto ;background-image: url("images/loading-42.gif");
  background-repeat: no-repeat;background-position: center center;
}
body.inactive .loadcontent{
opacity:1;
}
body.active .loadcontent{
opacity:0;z-index:-1;
}
h1,h2,h3,h4{font-family:Courgette, Arial, sans-serif;}
span.required{color:red;font-family:Lato, Arial, sans-serif;font-size:12px!important;}
div.logo {text-align:center;display:inline-block;
font-family:Arial, sans-serif;font-size:1.6em;font-weight:700;color:#333;background:#fff;padding:5px 15px;line-height:0.8em;}
div.logo span{font-size:1.7em;display:inline-block;}
div.logo span.slogen{font-size:0.3em;display:block}
div.logo img{width:50px;height:auto}
@media (max-width:1000px){
div.logo {font-size:1.4em;padding:3px 10px;}
div.logo img{width:30px;}
}
input.password{
font-family: password;
}
input.password.active{
font-family:Lato, Arial, sans-serif;
}
.alert {visibility: hidden;
animation: alertfadeIn 1s ease-in-out forwards;
 transform: rotateX(90deg); /* Elforgatás 90 fokkal */
  transform-origin: center bottom;
padding:0;margin-bottom:0;position:relative;
 	  }
 .tab-content .alert{
position:absolute;top:0;left:0;width:100%;
 }
  @keyframes alertfadeIn {
      from {visibility: hidden; height:0;transform: rotateX(90deg); 
        opacity: 0; padding:0 1rem;margin-bottom:0;
      }
      to {transform: rotateX(0deg);height:auto;
        opacity: 1;visibility: visible;
padding:1rem 1rem;margin-bottom:1rem;
      }
    }  
.alert.fadeOut {
animation: alertfadeOut 1s ease-in-out forwards;
  transform-origin: center bottom;
}
@keyframes alertfadeOut {
      from {transform: rotateX(0deg);height:auto;
        opacity: 1;visibility: visible;
padding:1rem 1rem;margin-bottom:1rem;
      }
      to {visibility: hidden; height:0;transform: rotateX(90deg); 
        opacity: 0; padding:0 1rem;margin-bottom:0;
      }
    }  
a, .btn{ transition: all .3s ease;}
a:hover, .btn:hover, .btn:focus{ box-shadow:none!important;transition: all .3s ease;}
.bg-dark a {color:#f3f3f3!important;text-decoration:none;}
.bg-dark a:hover {color:#eee!important;}
a.btn-primary.btn-lg, .btn-primary{color:#fff!important;background-color:#514EF9;border-color:#514EF9}
a.btn-primary:hover, .btn-primary:hover{color:#fff;background-color:#787878;border-color:#787878}
a.btn-primary:focus, .btn-primary:focus, a .btn-primary:active, .btn-primary:active{color:#333!important;background-color:#fff!important;border-color:#868686!important}
a.btn-secondary, .btn-secondary{color:#fff!important;background-color:#1ECD5E;border-color:#1ECD5E}
.btn-light{color:#333;background-color:#e1e6ea;border-color:#899aab}
.btn-light:hover{color:#fff!important;background-color:#514EF9;border-color:#514EF9}
button.btn.fbbutton{background:#0866FF;color:#fff}
button.btn.fbbutton i{font-size:1.5em;}
form div{position:relative;}
form i{cursor:pointer}
form input + i{}
        #videoContainer {
            position: relative;
            width: 100%;
            height: calc(100% - 60px);
            background-color: #ddd;
            display: flex;
        }
  #videoContainer  > div{
            height: 100%;
            position:relative;z-index:1;
        }
		#videoContainer  > div.VideoScreen{background:#333;border-radius:3px; flex: 1;}
		#videoContainer  > div.VideoChat{width: 0;padding:0;visibility: hidden;transition: all .3s ease;
		overflow:hidden;}
		#videoContainer  > div.VideoChat.active{width:25%;visibility: visible;transition: all .3s ease;
		}
		#videoContainer.chat  > div.VideoScreen{width:75%;}
		#videoContainer.chat  > div.VideoChat{background:#fff;width:25%;padding:5px;}

		#videoContainer  > div.VideoChat > div{display:flex;padding:5px;height: 100%;flex-direction: column;}
		#videoContainer  > div.VideoChat > div textarea{resize: none;height:50px;}
		#videoContainer  > div.VideoChat > div > div.chats{padding:8px;border:1px solid #ddd;border-radius:3px;
		background-color: #fff;flex: 1;
  overflow: hidden;display: block;
  overflow-y: scroll;
  scrollbar-width: thin; /* Vékony görgetősáv Firefoxban */
  scrollbar-color: #333 #ddd; /* Görgetősáv színei Firefoxban */}
	#videoContainer > div.VideoChat > div > div.chats p {border-radius:5px;
    position: relative;
    line-height: 1em;
}	
#videoContainer > div.VideoChat > div > div.chats p > span.text{padding: 10px; display: inline-block;background-color: #f3f3f3;max-width: 90%;}
#videoContainer  > div.VideoChat > div > div.chats p span.read{ position:absolute;bottom:3px;right:-20px;width:15px;height:15px;}
		#videoContainer  > div.VideoChat > div > div.chats p span.read:after{ content:"\2713"; color: #ddd;}
		#videoContainer  > div.VideoChat > div > div.chats p span.read.read-0:after{color: #bcbcbc;}
		#videoContainer  > div.VideoChat > div > div.chats p span.read.read-1:after{color: green;}
		#videoContainer  > div.VideoChat > div > div.chats p span.created{font-size:0.6em;margin-top:5px;display:block;color: #6f6f6f; }
        #videoContainer  > div.VideoChat > div > div.chats p.provider{text-align:right}
		#videoContainer  > div.VideoChat > div > div.VideoChatInput{position:relative;margin-top:8px;height:60px;padding:8px;background-color: #eee;}
		#videoContainer  > div.VideoChat > div > div.VideoChatInput .btn{top:8px;}
       #videoContainer  > div.VideoScreen > video {background-color: #000;z-index:1;
            width: 100%;
            height: 100%;
         border-radius:3px;
		 position:absolute;top:0;left:0;
        }
        #videoContainer.fullscreen > video {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
		.my-camera{z-index:9999;
		position:absolute;top:10px;left:10px;width: 200px;
        height: auto;
		border:1px solid #333;border-radius:3px;
        cursor: grab;
		display:none;
		}
.my-camera video {position:relative;z-index:-1;
    width: 100%;
    height: auto;
	margin:0;display:block;
}
		.my-camera.hide{
		top:auto;cursor:pointer;
        bottom:20px;background:#333;
		left:10px;width: 200px!important;
        height: 25px!important;
		}
.my-camera.hide span{display:inline-block;width: auto;text-align:center}
.my-camera.hide span{display:block;width: 200px;}
.slotcountdown{ position:absolute;top:50%;left:50%;text-align:center;margin-top:-77px;margin-left:-77px;width:150px;line-height:150px;border-radius:50%;z-index:9999;background:rgba(0,0,0,0.7);}
.slotcountdown:after{content: '';
 animation: rotate 2s linear infinite;
 position:absolute;top:0;left:0;  
 width:150px;height:150px;border-radius:50%;
 border: 5px solid transparent;
    border-top: 5px solid #4caf50;
    border-right: 5px solid #2196f3;
    border-bottom: 5px solid #ff5722;
    border-left: 5px solid #ffc107;
    animation: rotate 2s linear infinite;
}
@keyframes rotate {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
.slotcallstatus{position:absolute;background:transparent;z-index:9999999;top:calc(50% + 100px);left:50%;color:#fff;
text-align:center;margin-left:-200px;width:400px;font-size:1.5em;display:table;}
.slotcallstatus span{line-height:1.1em;display:table-cell;}
.slotcallstatus #connect-button{display:table-cell;margin-bottom:5px;}
.slotcountdown span{color:#d2d2d2;font-size:2em;display:inline-block}
.slotcountdown span.sec, .slotcountdown span.min{width:50px;text-align:center}
.my-camera span{z-index:99999;}
.my-camera .bi-chevron-up{display:none}
.my-camera.hide video{display:none}
.my-camera.hide .bi-chevron-up{display:block}
.my-camera.hide .bi-chevron-down{display:none}
.my-camera span{color:gray;z-index:9999999;border-radius:50%;background:#333;font-size:0.8em;width: 20px;
            height: 20px;text-align:center}
.my-camera span.closespan{cursor:pointer}
        div.controls {
            z-index:999;background:rgba(0,0,0,0.7);
            width: 100%;
			display:block;
            height: 60px;
		   text-align:center;
        }
		.controls button{position:relative;
            display: inline-block;margin:5px;box-shadow:none;background:transparent;
		border:1px solid gray;
		}	
		.controls button.active{box-shadow:none;background:green;
		border:1px solid green;
		}
		.controls button#chatIcon, .controls button#fullscreenBtn{border:1px solid transparent;}
		.controls button#chatIcon i, .controls button#fullscreenBtn i {}
		
		.controls button.tooltip-button.unread:after{
		content:"*"; font-size:1.5em;color: red;position:absolute;top:-4px;right:0;
		}
        .controls i {
            font-size: 24px;
            cursor: pointer;
            color: gray; /* Inaktív ikonok színe */
        }
        .controls button.active i.active {
            color: #fff; /* Aktív ikonok színe */
        }
         .controls i.active {
            color: green; /* Aktív ikonok színe */
        }

        #waitingMessage {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            color: white;
            font-size: 24px;
            animation: pulsate 1.5s infinite; /* Folyamatos animáció */
        }
        @keyframes pulsate {
            0%, 100% {
                opacity: 0.7;
                transform: scale(1);
            }
            50% {
                opacity: 1;
                transform: scale(1.1);
            }
        }
.form-control:focus, .form-select:focus{color:#212529;background-color:#fff;border-color:#ddd;outline:0;box-shadow:0 0 0 .2rem rgba(45,45,45,.15)}
button span {
            position: relative;
            display: inline-block;
        }
		
        button.inactive span.strikethrough::after {
            content: '';
            position: absolute;
            top: 50%;
            left: -4px;
            right: -4px;
            height: 2px; /* A vonal vastagsága */
            background-color: gray; /* A vonal színe */
             transform: translateY(-50%) rotate(45deg);
            z-index: 1;
        }
        .strikethrough i {
            position: relative;
            z-index: 2; /* Az ikon a vonal felett legyen */
        }  
.lines {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  margin: auto;
  width: 90vw;
  display: flex;
  z-index:1;
  justify-content: space-between; /* Distribute lines evenly */
}
.front-container.container-fluid{position:relative;z-index:99;}
.line {
  position: relative;
  width: 1px;
  height: 100%;
  background: transparent;  /* Line color */
  overflow: hidden;
}

.line::after {
  content: '';
  display: block;
  position: absolute;
  height: 15vh;
  width: 100%;
  top: -50%;
  left: 0;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #ffffff 75%, #ffffff 100%);
  animation: drop 7s 0s infinite;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(0.4, 0.26, 0, 0.97);
}

/* Different colors for each line's pseudo-element */
.line:nth-child(1)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #FF4500 75%, #FF4500 100%);
  animation-delay: 0.5s;
}

.line:nth-child(2)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #32CD32 75%, #32CD32 100%);
  animation-delay: 1s;
}

.line:nth-child(3)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #1E90FF 75%, #1E90FF 100%);
  animation-delay: 1.5s;
}

.line:nth-child(4)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #FFD700 75%, #FFD700 100%);
  animation-delay: 2s;
}

.line:nth-child(5)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #8A2BE2 75%, #8A2BE2 100%);
  animation-delay: 2.5s;
}

.line:nth-child(6)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #20B2AA 75%, #20B2AA 100%);
  animation-delay: 3s;
}

.line:nth-child(7)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #DC143C 75%, #DC143C 100%);
  animation-delay: 3.5s;
}

.line:nth-child(8)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #00FA9A 75%, #00FA9A 100%);
  animation-delay: 4s;
}

.line:nth-child(9)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #FF1493 75%, #FF1493 100%);
  animation-delay: 4.5s;
}

.line:nth-child(10)::after {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #00BFFF 75%, #00BFFF 100%);
  animation-delay: 5s;
}

@keyframes drop {
  0% {
    top: -50%;
  }
  100% {
    top: 110%;
  }
}

	footer {width: 100%;
    position: fixed;
    bottom: 0;
	z-index:9999
  }
  
footer div.btn-primary, footer div.btn-primary:hover{background-color:#2d27f8!important;}
   label span.required, legend span.required, div span.required {
  color: red;font-size:1.2em;
  margin-left: 5px;display:inline-block!important;
}
.modal form label, form.login label {font-weight:500;}
 .nav-tabs .nav-link, .tab-content .nav-link{color:#333;background-color:#f7f7f7;border-color:#ddd #ddd #fff}
.nav-tabs .nav-link.active, .tab-content .nav-link.active{color:#fff;background-color:#333;border-color:#000 #000 #000}
.tab-content{position:relative;width:100%;background-color:#f7f7f7;border:1px solid #ddd;}
 .nav.nav-tabs{white-space:nowrap!important;max-width:auto!important;width:auto!important;}
 .nav.nav-tabs li.nav-item{display:inline-block;position:relative;}
 .nav.nav-tabs li.nav-item span.tab-alert{color:#fff;display:inline-block;padding:0;font-size:14px;border-radius:50%;position:absolute;
 background-color:red;width:15px;text-align:center;line-height:16px;right:1px;top:1px;}
  .nav.nav-tabs li.nav-item span.tab-alert i{margin:0;}
 .nav.nav-tabs li.nav-item span.required{background:#fff;
 border-radius:50%;width:10px;line-height:15px;font-size:1.3em;height:10px;text-align:center;position:absolute;color:red;top:3px;right:3px;}
.tab-content {  position: relative; overflow: hidden;
}
form input.select-imput{ display:inline-block;position:relative;background-color:#fff;font-size:16px;
max-width:100%; background-size:auto 50% ;background-image: url("images/Chevron-Down-512.webp");
  background-repeat: no-repeat;background-position-x: 98%;background-position-y: 12px;}
.custom-select-wrapper, .custom-select-wrapper .list-group{width:100%;}
.custom-select-wrapper{}
.custom-select-wrapper .list-group{border-radius:5px;z-index:-1;max-height:0;visibility: hidden;transition: all .3s ease;
		overflow-y:hidden; top:-38px;transform-origin: center top; }
 .custom-select-wrapper.active .list-group{z-index:999;max-height:300px;visibility: visible;transition: all .3s ease;
 overflow: -moz-scrollbars-vertical;
		overflow-y:scroll; color:#000;
scrollbar-width: thin; 
scrollbar-color: #333 #ddd; }
input[type="checkbox"], input[type="radio"]{box-shadow:none!important;
}
input[type="checkbox"]:checked, input[type="radio"]:checked {
  background-color: green !important;
  border-color: green !important;
}
 .upload-area {
      border: 2px dashed #ddd;
      padding: 20px;
      text-align: center;
      cursor: pointer;
	  position:relative;
    }
    .upload-area.dragover {
      background-color: #e9ecef;
    }
	.upload-area input{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;
	}
    .preview-container {position:relative;
      text-align: center;max-width: 150px;max-height: 150px;min-width: 150px;min-height: 150px;line-height:150px;vertical-align:middle;
    } 
	.preview-container span{position:absolute;cursor:pointer;font-size:0.9em;width:28px;line-height:28px;right:0;top:0;z-index:999;background:#333;border-radius:50%;color:#fff;}
    .preview-container img {
      height: auto;
      width: auto;
      max-width: 130px;
      max-height: 130px;
    }
	label {font-weight:700}
	label span{font-weight:400}
.bg-success{background-color:#2eb700!important}
a.download{position:relative;display:inline-block;height:150px;}
a.download img{display:block;}
a.download span{position:absolute;font-size:3em;top:0;left:0;width:100%;line-height:150px;text-align:center;color:#7d7d7d;
background:rgba(255,255,255,0.7);opacity:0;transition: all .3s ease;}
a.download:hover span{opacity:1;transition: all .3s ease;}
#timeRange {
    width: 100%;
    margin-top: 10px;
}
.hidden-data{position:relative;opacity:0.5;transition: all 1s ease;}
.hidden-data:after{ content: '';width: 100%;height: 100%;top:0;left:0;position:absolute;background:transparent;}
.noUi-horizontal .noUi-tooltip { 
  bottom:-40px 
}
.avatar-img{width:auto;height:auto;max-width:100%;max-height:250px;}

p.lead{font-size:0.9em;}
p.lead strong, p.lead a, .list-group-item a{font-weight:700!important;color: #000}
span.insertorder{margin:10px;padding:10px;background:#eee;border:1px solid #333;border-radius:8px;}
span.insertorder p{line-height:1em;font-size:1em;margin:0 0 5px 0;}
#partnestatus{position:absolute;bottom:10px;left:10px;line-height:20px;z-index:9999;color:#fff}
#partnestatus div{margin-left:10px;width:20px;height:20px;border-radius:50%;background:red;}
.countdown{position:fixed;top:0;left:0;width:100%;background-color:rgba(0,0,0,0.7);z-index:999;  display: flex;
            flex-direction: column;text-align:center;
            min-height: 100vh!important;background-size:auto 50% ;
			background-image: url("images/09-45-44-954_512.webp");
  background-repeat: no-repeat;background-position: center center;}
.countdown .countdown-minutes{  font-size:7em;color:#ddd}
.countdown .countdown-minutes span{}
.bg-custom {background:#f0f0f0;}
div.view{line-height:2em;vertical-align:middle}
div.view i{cursor:pointer;font-size:1.8em}
#connection-status {position:absolute;z-index:999;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;width: 100%;
  background-color: #0d1117;
  color: #ffffff;
  font-family: 'Arial', sans-serif;
  text-align: center;
  animation: fadeIn 1s ease-in-out;
}
#connection-status.active {display:flex;}
.status-message {
  font-size: 1.5rem;
  margin-top: 20px;
}

/* Kör animáció a "Connecting" állapothoz */
.circle-spinner {
  width: 50px;
  height: 50px;
  border: 6px solid rgba(255, 255, 255, 0.3);
  border-top: 6px solid #ffffff;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Animált pöttyök a "Waiting for response" szakaszhoz */
@keyframes dots {
  0%, 20% {
    content: ".";
  }
  40% {
    content: "..";
  }
  60% {
    content: "...";
  }
}

.status-message.waiting::after {
  display: inline-block;
  animation: dots 1s steps(1, end) infinite;
}

/* Forgás animáció */
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Fade-in animáció */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.refreshcaptcha i{font-size:1.4em;}
.page-item.active .page-link{background:#333;border-color:#333}
.pagination li a{color:#333}
.g-signin2 {width:100%!important}
 .caret-container {
 font-weight:300;
        line-height: 1em;
		margin-bottom:-8px;margin-right:-5px;
    }
    .caret-rotated {
        display: inline-block;
        font-size: 16px; /* Opcionális méret */
        padding: 0;
        margin: 0;
    }
    .order-up, .order-down {
        cursor: pointer;
    }
	.copylink{cursor: pointer;}
@media (max-width: 767.98px) {
  .form-select {
    font-size: 0.875rem; /* form-select-sm betűmérete */
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    /* Egyéb form-select-sm stílusok, ha szükségesek */
  }
  }
  .form-select {
font-family: monospace, 'Lato', Arial;
}
#update-success {
  position: fixed;
  bottom: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  height:auto !important;width:auto !important;
  z-index: 99999 !important; /* Ennél a z-index-nél magasabb kell, mint a modal */
}

#update-success.active {
  opacity: 1;
  visibility: visible;
  display: inline-block; /* Vagy inline-block, attól függően, mire van szükséged */
}
.modalcountdown {
  display:block;
    font-family: 'Courier New', Courier, monospace; /* Monospace betűtípus */
    font-size: 2em; /* Megfelelő méret */
    font-weight: bold;
    display: block;
    text-align: center;
    padding: 10px;
}
.chat-box{position:fixed;bottom:20px;right:20px;width:300px;max-height:400px;
background:#fff;border-radius:12px;overflow:hidden;flex-direction:column;z-index:1050;
}
.chat-header.bg-primary{cursor:pointer;background-color:#514EF9!important;}
.chat-body{flex:1;overflow-y: scroll; max-height:260px;
  scrollbar-width: thin; /* Vékony görgetősáv Firefoxban */
  scrollbar-color: #333 #ddd; /* Görgetősáv színei Firefoxban */
}
.chat-header .btn.btn-success {background:transparent;color:white;}
.chat-header #mic-toggle.btn{padding:5px!important;font-size:22px!important;line-height:1em;border-radius:50%}
.chat-header #mic-toggle.btn-primary{background-color:#2d27f8;border-color:#2d27f8}
.chat-header #mic-toggle.btn-primary:hover{background-color:green;border-color:green}
.chat-messages{display:block;}
.bot-message{line-height:1.1em;background:#e9f2ff;border-radius:10px;padding:8px 10px;text-align:left;margin-right:5%;max-width:95%;}
.user-message{line-height:1.1em;background:#d1ffd6;border-radius:10px;padding:8px 10px;text-align:right;margin-left:5%;max-width:95%;}
.chat-messages > div{margin-bottom:8px;}
.chat-messages > div:last-child{margin-bottom:0;}
.chat-input .input-group textarea{resize:none;line-height:1.1em;  scrollbar-width: thin; 
  scrollbar-color: #333 #ddd;width:calc(100% - 95px); }
.loadwebrtc{z-index:999;background-color:rgba(255,255,255,0.7);
background-size: 60px auto ;background-image: url("images/load.gif");
  background-repeat: no-repeat;background-position: center center;
}
.ai-voice-indicator{z-index:999;background:rgba(255,255,255,0.7)!important}
.ai-voice-indicator > div {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #7b79fa, #514EF9 70%);
  box-shadow: 0 0 35px rgba(81, 78, 249, 0.5);
  transition: transform 0.05s linear, box-shadow 0.1s linear;
  margin-top:-50px
}
.chat-closed .chat-body,.chat-closed .chat-input{display:none;}
.chat-box.chat-closed{width:60px!important;height:60px;border-radius:50%;background:#514EF9;padding:0;text-align:center;display:block;text-align:center;-webkit-box-shadow: 0px 0px 15px 5px #FFFFFF; 
box-shadow: 0px 0px 15px 5px #FFFFFF;}
.chat-closed button{margin:10px auto!important}
.chat-closed #chat-header span{display:none;}
.typing {
  display:inline-block;
  line-height:1.1em;
  margin-top:10px;
}
.typing span {
  display:inline-block;
  width:6px;
  height:6px;
  margin:0 2px;
  background:#707070;
  border-radius:50%;
  animation: blink 1.4s infinite both;
}
.typing span:nth-child(1){animation-delay:0s;}
.typing span:nth-child(2){animation-delay:0.2s;}
.typing span:nth-child(3){animation-delay:0.4s;}

@keyframes blink {
  0%,80%,100% {opacity:0;}
  40% {opacity:1;}
}