@charset "UTF-8";

body, h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4 {
/*	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo,"Roboto", "sans-serif"  !important;	*/	
	/*font-family: "Roboto","Arial", "Helvetica","tbudrgothic-std","sans-serif"   !important ;*/
}

body,h1,h2,h3,h4,h5,p,li,span {
  font-family:
    "Inter",
    "Roboto",
    "Meiryo",
    "Noto Sans JP",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    "Helvetica Neue",
    Arial,
    "Hiragino Sans",
    "Yu Gothic",
    sans-serif 
    !important;
}

html, body{
	width:100%;
	height:100%;
	min-height: 500px;
}

body{
padding-right:0 !important;
}

a,a:hover, a:focus {
    color: #6a5acd !important;
    text-decoration: none;
}


.index-page,.index-page .wrapper{
	height: 100%;
	width:100%;
    background-color: transparent;
    position: relative;
	overflow: hidden;
}

.index-page .wrapper{
    margin: 0;
    height: 100%;
	width:100%;
	background-color: #eeeeee;
}

.index-page .main{
    margin: 0;
    padding: 0;
    background-color: #ffffff;
    box-shadow: none;
    position: relative;
    height: 100%;
	width:100%;
}

/*操作パネル--------------------------------*/

.index-page .panelarea{	
	z-index:200;
	position:absolute;
	bottom:50px;
	width:100%;
	display:flex;
	justify-content: center;

}

/*video用*/
.index-page .panel_video{	
	display:flex;
	justify-content: center;
	height:50px;
	width:280px;
	/*background-color:#6a5acd;*/
	background-color: rgba(106, 90, 205, 0.6);
/*	background-color: rgba(0, 0, 0, 0.4);*/
	padding:5px 15px;
	border-radius:25px;
	overflow: hidden;	
}

.index-page .panel_video>div{
	height:100%;
	width:20%;
	padding: 5px;
}

.index-page .panel_video>div.bt{
	width:40%;
	padding: 0 5px;
}

.index-page .panel_video>div>img{
	height:100%;
}

.index-page .panel_video .btn{
	padding:7px 20px !important;
	width:80px;
}

/*video_agent用*/
.index-page .modal .ag_cmr{
	border: solid 1px #999999;
	border-radius: 20px;
		padding:15px 5px 10px;
	margin:30px 30px;
}

.index-page .panel_agent{	
	display:flex;
	justify-content: center;
	height:50px;
	width:280px;
	/*background-color:#6a5acd;*/
	background-color: rgba(106, 90, 205, 0.6);
/*	background-color: rgba(0, 0, 0, 0.4);*/
	padding:5px 15px;
	border-radius:25px;
	overflow: hidden;	
}

.index-page .panel_agent>div{
	height:100%;
	width:20%;
	padding: 5px;
}

.index-page .panel_agent>div.bt{
	width:40%;
	padding: 0 5px;
}

.index-page .panel_agent>div>img{
	height:100%;
}

.index-page .panel_agent .btn{
	padding:7px 20px !important;
	width:80px;
}


/*voice_only用*/
.index-page .panel_voice,
.index-page .panel_voice > div{	
	width:100%;
	text-align: center;
}

.index-page .panel_voice .btnmsg{
    font-size: 0.9em;
    color:#6a5acd;
    margin-top: 0px;
	display:none;
}

.index-page .panel_voice button{
    width:150px;
}

.index-page .panel_voice i{
    font-size:28px;
}

/*追加操作パネル表示 ----------------------------------------------20231025------*/

.index-page .subarea{
	z-index:100;
	position:absolute;
	bottom:60px;
	width:100%;
	display:flex;
	/*justify-content: center;*/
}

.index-page .panel_circle{	
	display:flex;
	justify-content: center;
	height:46px;
	width:46px;
	background-color: rgba(106, 90, 205, 0.6);
	padding:8px 15px 5px;
	border-radius:23px;
	overflow: hidden;
	position: absolute;
	bottom:0;
	left:-50px;
}

.index-page .panel_circle img{
	width:30px;	
}


.index-page .panel_circle.vcam.in{		
	animation: vcam_in 2s ease 0s !important;
	animation-fill-mode: forwards !important;
}
@keyframes vcam_in {
    0% {left:-50px;opacity:0;}
	40% {opacity:0.5;}
    100% {left:calc(50% - 50px);opacity:1}
}

.index-page .panel_circle.share.in{
	animation: share_in 1s ease 0s !important;
	animation-fill-mode: forwards !important;
}
@keyframes share_in {
    0% {left:-50px;opacity:0;}
	20% {opacity:0.5;}
    100% {left:calc(50% + 4px);opacity:1;}
}


.index-page .panel_circle.vcam.out{	
	animation: vcam_out 3s ease 0s !important;
	animation-fill-mode: forwards !important;
}
@keyframes vcam_out {
	0% {left:calc(50% - 50px);opacity:1;}
	60% {opacity:0.5;}
	100% {left:-50px;opacity:0;}
}

.index-page .panel_circle.share.out{
	animation: share_out 1s ease 0s !important;
	animation-fill-mode: forwards !important;
}
@keyframes share_out {
    0% {left:calc(50% + 4px);opacity:1;}
	80% {opacity:0.5;}
	100% {left:-50px;opacity:0;}
}


/*********************************************/




/*video表示--------------------------------*/
.index-page .vd .snapshot {
    display: block;
    z-index: 70;
    position: absolute;
    right: 55px;
    top: 8px;
    width: 30px;
    height: 30px;
    color: #ccc;
}

.index-page .vd .snapshot img {
    width: 35px;
}

.index-page .vd .snapshot i{
	font-size: 35px;
}

.index-page .vd{
	width:100%;
	height:100%;
	justify-content: center;
	overflow: hidden;
	background-color: rgba(106, 90, 205, 0.15);
}

.index-page .vd video{
	height: 100%;
}


.index-page .vd .tgl{
	position:absolute;
	z-index:100;
	width:40px;
	height:40px;
	margin-top:6px;
}

.index-page .vd .tgl img{
width:40px;
}

.index-page .vd .selfp{
	z-index:100;
	position:absolute;
	bottom:110px;
	left:5px;
	width:99px;
	height:132px;
	overflow: hidden;
	display: flex;
	justify-content: center;
}

.index-page .vd .selfp video{
	height: 100%;
}

.index-page .vd .mic_status{
	z-index:50;
	position:absolute;
	left:55px;
	top:10px;
	border: solid 1px #777777;
	border-radius: 5px;
	padding:7px 3px 0px;
	color:#777777;
}

.index-page .vd .mic_status i{
	font-size: 20px;
}

.index-page .vd .display_style{
	display: block;
	z-index:60;
	position:absolute;
	right:10px;
	top:10px;
	width:30px;
	height:30px;
}

.index-page .vd .marker_switch{
	display: block;
	z-index:90;
	position:absolute;
	left:10px;
	top:10px;
	width:30px;
	height:30px;
}

.index-page .vd .marker_switch img{
	width:35px !important;
}



/*reCaptcha表示---------------------------------*/

.grecaptcha-badge { visibility: hidden; }/*badge非表示*/

.index-page .recaptcha{
	width:100%;
	position:absolute;
	z-index: 2;
	bottom:0;
	color: #6a5acd;
	font-size:12px;
	line-height:12px;
	text-decoration: none;
	display:flex;
	justify-content: center;
	align-items:stretch;
}

.index-page .recaptcha>div:nth-child(1){
	width:70px;
	padding:0 0 5px 10px;
	margin-right:10px;
	text-align: right;
	display:flex;
	align-items:center;
}

.index-page .recaptcha>div:nth-child(2){
	padding:0 10px 5px 0;
}

.index-page .recaptcha img{
	width:50px;
}


/*default表示---------------------------------*/

.index-page .default{
	width:100%;
	height:100%;
}

.index-page .mybrand{
    background-color: #6a5acd;
    width:100%;
    padding: 20px;
	text-align: center;
}

.index-page .mybrand h1{
    font-size: 20px;
    letter-spacing: 0.2em;
    font-weight: 600;
    line-height: 0px;
    margin: 0px;
    color: #FFFFFF;
}


.index-page .box{
    width:200px;
    height:130px;
    margin: 40px auto 0 auto;
   /* background-image: url("../../img/logo_tolfa_black.png");*/
    background-repeat:no-repeat;
    background-position: center center;
    background-size:contain;
}


.index-page .clt-name{
	margin-top:30px;
    width:100%;
	text-align: center;
	padding: 0 5%;
    font-size: 1.2em;
    color:#6a5acd;
}

.index-page .lead{
	margin-top:40px;
    width:100%;
	text-align: center;
	padding: 0 5%;
    font-size: 0.9em;
    color:#6a5acd;
}


/*モーダル---------------------------------*/

#allow_video{/*表示調整*/
	padding-right:0 !important;
}

.modal .modal-dialog {
    margin-top: 50px;
}

.modal-body div{
    padding-left:20px;
}

.modal div.input-group{
	margin:20px 0;
	text-align: left;
}

.form-check .form-check-input:checked ~ .circle {
    border-color:#4caf50 !important; }

.form-check .form-check-input:checked ~ .circle .check {
    background-color:#4caf50 !important; }

.modal-body i{
    color:#6a5acd;
}

/*マイク許可イラスト---------------------------------*/

table.mic_allowed{
    width: 80% !important;
    border-collapse: collapse !important;
    margin: 20px auto 30px;
}

table.mic_allowed td{
    text-align: center !important;
    width: 20% !important;
    padding: 10px !important;
    border: solid 1px #6a5acd !important;
}

table.mic_allowed tr:nth-child(1)>td{
    text-align: left !important;
    background-color: #6a5acd;
    color: #ffffff !important;
}

table.mic_allowed i.mic{
    font-size: 40px !important;
    margin: auto 15px auto -15px !important;
    color: #ffffff !important;
    vertical-align: 0px !important;
}
/*
div.touch{
    position: absolute;
    z-index: 100;
    color: #4caf50 !important;
    font-size: 50px !important;
    width: 50px;
    height: 50px;
    border-radius: 25px;
    margin-left: 14%;
    margin-top: -25px;
    animation: anime1 4s ease 0s !important;
}

div.touch i{
    color: #4caf50 !important;
    font-size: 50px !important;
    position: relative;
    margin-top: 10px !important;
    margin-left: -18px !important;
    background-color: transparent;
}

@keyframes anime1 {
    0% {margin-left:40%;margin-top:0px;}
    50% {margin-left:14%;margin-top:-25px;}
    60% {background-color: transparent;}
    75% {background-color:#FEA9C9;}
    100% {background-color: transparent;}
}
*/
/*---------*/

#message-code {
    margin-top: 12px;
}
#message-code > span {
    /*
    font-size: 22px;
    color:#FFB803;
   */
}

#message-code i{
    font-size: 16px;
}

/*dialpad---------------------------------*/
.index-page .dialpadarea{
	position:absolute;
	z-index: 10;
	top:27%;
	width:100%;
	text-align: center;
}

#dialpad{
  margin: 10px 0 5px;
}

#dialpad .btn{
  background-color: #6a5acd;
  margin: 3px 5px;
  font-size: 30px;
}

#dialpad span{
  display: block;
  margin: 0;
  color: #ffffff;
}

#dialpad .btn.btn-fab.btn-fab-mini{
  padding: 0px;
  height: 50px !important;
  min-width: 50px !important;
  width: 50px !important;
}

#dialpad .ripple.ripple-on {
  transition: opacity 0s linear 0s, transform 0.1s ease-out 0s !important;
  opacity: 0.7;
}

#dialpad .ripple.ripple-out {
  transition: opacity 0.1s ease-out 0s !important;
  opacity: 0;
}

.dialpad-shown .device {
    display:none;
}
.dialpad-shown .lead {
    display:none;
}
.dialpad-shown .box {
    display:none;
}

/*追加***********************************************************************20231025*/

.index-page .default .box.in,
.index-page .default .lead.in,
.index-page .default .clt-name.in{
	display:block !important;
	animation: fade_in 3s ease 0s !important;
	animation-fill-mode: forwards !important;
}

@keyframes fade_in {
    0% {opacity:0;}
	100% {opacity:1;}
}

@keyframes fade_out {
    0% {opacity:1;}
	100% {opacity:0;}
}

.index-page .default .box.out,
.index-page .default .lead.out{
	display:none !important;
	opacity:0;
}

.index-page .dialpadarea.in{
	display:block !important;
	animation: dialpad_in 3s ease 0s !important;
	animation-fill-mode: forwards !important;
}

@keyframes dialpad_in {
    0% {opacity:0;}
	100% {opacity:1;}
}

.index-page .dialpadarea.out{
	display:block !important;
	animation: dialpad_out 1s ease 0s !important;
	animation-fill-mode: forwards !important;
}

@keyframes dialpad_out {
    0% {opacity:1;}
	100% {opacity:0;}
}


/*********************************************/




/* optional buttons */
#optional-buttons {
  /*height: 0;*/
}

#optional-buttons .btn {
  padding: 0;
  margin-bottom: 0;
  height: 38px;
  width: 38px;
}

/*chat*/
.index-page .chat{
	position:absolute;
	z-index: 400;
	bottom:0;
	width:100%;
	max-width: 500px;
	top:calc(100% - 22px);
	background-color: rgba(195, 187, 246, 0.8);
	color: #000000;
}

.index-page .chat .slide{
	width:100%;
	height:22px;
	display: flex !important;
	justify-content: center;
	align-items:center;
}

.index-page .chat .slide .bararea{
	width:140px;
	height:100%;
	padding: 8px 20px;
}

.index-page .chat .slide .bar{
	width:100px;
	height:6px;
	background-color: #eeeeee;
	border-radius: 2px;
}

.index-page .chat .area
{
	display: flex !important;
	justify-content: center;
	width:100%;
	height:calc(100% - 30px - 60px);
	padding: 10px 2% 10px 0;
}

.index-page .chat iframe{
	width:100%;
	border:0px;
	height:100% !important;
}

.index-page .chat .inputbox{
	display: none;
	justify-content: center;
	align-items:center;
	width:100%;
	height:60px;
	position:absolute;
	bottom:0;
	background-color: rgba(106, 90, 205, 0.3);
}


.index-page .chat .inputbox>textarea{
	border: 0;
	height:2.3em !important;
	line-height:1em;
	width:60%;
}



.talk-page,.talk-page .wrapper,.talk-page .main{
	height:100%;
	background-color: transparent;
	color: #000000;
}

.talk-page .talkbox{
	display:flex;
	align-items:flex-start;
	margin:15px 15px;
}

.talk-page i{
	font-size:30px;
}

.talk-page .agent .icon{
	width:30px;
	height:30px;
	color:#444444;
}

.talk-page .customer .icon{
	width:30px;
	height:30px;
	color: #5240c5;
}

.talk-page .time{
	font-size: 12px;
}

.talk-page .talk{
	margin:0 10px;
	padding: 5px 10px;
	background-color: #ffffff;
	width: 70%;
	border-radius: 7px;
	font-size: 15px;
	text-justify:inter-word;
}

.talk-page .talkbox.agent{
	justify-content: flex-end;
}

.talk-page .talkbox.customer{
	justify-content: flex-start;
}



/*autodemo*/

.autodemo .bal1{
	display: none;
	position:absolute;
	margin-top:-95px;
	margin-left:-100px;
	margin-right:10px;
	z-index:100;
	background-color: #fff0c6;
	border-radius:20px;
	padding: 10px 15px;
	font-size: smaller;
	max-width:300px;
}

.autodemo .bal1:before {
	content:"";
	position: absolute;
	left: 60%;
	width: 20px;
	height: 20px;
	bottom: -25px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .bal1:after {
	content:"";
	position: absolute;
	left: 55%;
	width: 15px;
	height: 15px;
	bottom: -40px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .tap1{

	position:absolute;
	margin-top:-25px;
	margin-left:55px;
	z-index:90;
	border-radius:50%;
	width:40px;
	height:40px;
	background-color: #FEA9C9;
	animation: tap_in 2s ease infinite alternate;
}

@keyframes tap_in {
    0% {opacity: 0.2;}
	100% {opacity: 1;}
}

.autodemo .tap2{
	display: none;
	position:absolute;
	margin-top:-25px;
	margin-left:55px;
	z-index:90;
	width:40px;
	height:40px;
}


.autodemo .allow_micsim{
	display:none;
	position: absolute;
	z-index: 90;
	top:100px;
	padding: 15px 15px 25px;
	border-radius:10px;
	background-color:#fff0c6;
	font-size: small;
	width:90%;
	max-width: 400px;
	/*
	display:flex;
	justify-content:center ;*/
}

.autodemo .allow_micsim .tbl_ios{
	width: 250px;
	border-radius:10px;
	background-color: #ffffff;
}

.autodemo .allow_micsim .tbl_android{
	width: 300px;
	border-radius:20px;
	background-color: #ffffff;
	font-size: smaller;
}

.autodemo .allow_micsim .tbl_ios td{
	padding: 15px 20px;
	text-align: center;
	font-weight: 600;
}

.autodemo .allow_micsim .tbl_android tr:nth-child(1) td{
	padding: 10px 20px;
	text-align: left;
	font-weight: 400;
	line-height: 20px;
}

.autodemo .allow_micsim .tbl_android i{
	color:#0095ff;
	margin:7px 10px 10px 0;
}

.autodemo .allow_micsim .tbl_android tr:nth-child(2) td{
	padding: 10px 20px;
	text-align: right;
	font-weight: 600;
	color:#0095ff;
}



.autodemo .allow_micsim .tbl_ios tr:nth-child(1) td{
	border-bottom: solid 1px #eeeeee;
}
.autodemo .allow_micsim .tbl_ios tr:nth-child(2) td:nth-child(1){
	border-right: solid 1px #eeeeee;
}
.autodemo .allow_micsim .tbl_ios tr:nth-child(2) td{
	color:#0095ff;
	width:50%;
}

.autodemo .inf2,
.autodemo .inf,
.autodemo .connect,
.autodemo .attention,
.autodemo .reconnect{
	display: none;
	position: absolute;
	z-index: 1000 !important;
	top:35%;
	padding: 25px;
	border-radius:10px;
	background-color:#fff0c6;
	font-size: small;
	width:90% !important; 
	max-width: 400px;
}

.autodemo .connect{
	top:20% !important; 
}

.autodemo .inf2,
.autodemo .attention,
.autodemo .reconnect{
	top:15% !important; 
}

.autodemo .ntc{
	display:none;
	position: absolute;
	z-index: 90;
	top:100px;
	padding: 25px;
	border-radius:10px;
	background-color:#fff0c6;
	font-size: small;
	width:90% !important; 
	max-width: 400px;
}

.autodemo .ntc:before {
	content:"";
	position: absolute;
	left: 10%;
	width: 20px;
	height: 20px;
	bottom: -25px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .ntc:after {
	content:"";
	position: absolute;
	left: 15%;
	width: 15px;
	height: 15px;
	bottom: -40px;
	background: #fff0c6;
	border-radius: 50%;
  }


  .autodemo .modal-dialog{
		max-width: 400px;
		font-size:small;
  }


  .autodemo .dlg{
	position: absolute;
	z-index: 90;
	bottom:-10px;
	left:15px;
	padding: 10px;
	border-radius:12px;
	line-height: 150%;
	background-color:#fff0c6;
	width: 200px!important; 
}

.autodemo .dlg:before {
	content:"";
	position: absolute;
	left: 210px;
	width: 20px;
	height: 20px;
	bottom: 10px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .dlg:after {
	content:"";
	position: absolute;
	left: 240px;
	width: 15px;
	height: 15px;
	bottom: 20px;
	background: #fff0c6;
	border-radius: 50%;
  }


  .autodemo .dlg2{
	position: absolute;
	z-index: 90;
	bottom:-40px;
	left:15px;
	padding: 10px;
	border-radius:12px;
	line-height: 150%;
	background-color:#fff0c6;
	width: 200px!important; 
}

.autodemo .dlg2:before {
	content:"";
	position: absolute;
	left: 210px;
	width: 20px;
	height: 20px;
	bottom: 20px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .dlg2:after {
	content:"";
	position: absolute;
	left: 240px;
	width: 15px;
	height: 15px;
	bottom: 30px;
	background: #fff0c6;
	border-radius: 50%;
  }

  .autodemo .fadein{
	display: block;
	animation: fade_in 1s ease 0s !important;
	animation-fill-mode: backwards !important;
	/*animation-fill-mode: forwards !important;*/
	
}


/*メディアクエリ--------------------------------*/
/*
none <576 
sm >=576　タブレット
md >=768　タブレット横
lg >=992　PC
xl >=1200
xxl >=1400
*/



@media (min-width: 459px){


	.index-page .chat{
		right:0;
	}

}


@media (max-height: 500px) {
.index-page,.index-page .wrapper{
	overflow:scroll;
}
}


@media (min-width: 576px){
	.index-page .vd .selfp{
	z-index:100;
	bottom:25px;
	left:20px;
	width:132px;
	height:155px;	
}	
}

@media (min-height: 701px) {
    .dialpad-shown #callui-incall {
        /*margin-top:20px;*/
    }
}

@media(min-width:992px){
	.index-page .vd .tgl{
	display:none;
}

.index-page .chat .area{
	padding-right:0;
}


}



