a {
    color: #007bff;
}
a:hover {
    color: #0069d9;
}
.maincolor {
    color: #007bff;
}
.hidden {
    display: none !important;
}
.footer-logos {
    display: none;
}
.font-size-1-1 {
    font-size: 1.1rem;
}
.font-size-0-9 {
    font-size: .9rem;
}
.font-size-0-8 {
    font-size: .8rem;
}
.btn-primary, .btn-primary:disabled {
    color: #fff;
    background-color: #0069d9;
    border-color: #0069d9;
}
.btn-primary:hover {
    color: #fff;
    background-color: #0051a1;
    border-color: #0051a1;
}
.btn-primary.search i {
    position: relative;
    top: 1px;
}
.dashboard-cards .card-body {
	padding: 0;
}
.row.dashboard-cards, .row.progress-cards {
	margin-left: 0;
	margin-right: 0;
}
.dashboard-cards .card-body table {
	margin-bottom: 0;
}
.dashboard-cards a.view-all {
	float: right;
}
.inline-info {
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
}
.scene-icon {
    font-size: 38px;
    position: relative;
    background: #467fd0d1;
    color: #fff;
    padding: 0 6px;
    display: flex;
    margin: 5px;
}
.scene-icon .scene-number {
    position: absolute;
    font-size: 16px;
    font-family: 'Source Sans Pro';
    width: 100%;
    text-align: center;
    left: 0;
    display: flex;
    height: 100%;
    justify-content: center;
    align-items: center;
    top: 0;
    margin-top: -2px;
}

/* Simulacion */
 .simulation-page {
    width: 100%;
    height: 100%;
    position: absolute;     
    background-size: cover;
    overflow: hidden;
    background-position: center bottom;
}
.simulation-page main {
    width: 100%;
    height: 100%;
    padding: 0 !important;
    background: #ffffff47;
}
.simulation-page .navbar {
    background-color: none !important;
    padding: 1.5rem 2rem;
}
.simulation-page .navbar-dark .navbar-toggler {
    border: none;
    color: #fff;
}
.simulation-page .navcases-right {
    position: absolute;
    right: 50px;
    background: #00000036;
    border-radius: 10px;
    padding: 20px 5px;
}
.simulation-page .navcases-right a {
    display: block;
    color: #ffffff59;
    font-size: 18px;
    font-weight: 700;
    padding: 10px;
}
.simulation-page .navcases-right a.active {
    color: #fff;
}
.simulation-body {   
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    padding-bottom: 5%;
    height: calc(100% - 90px);
}
.simulation-description {
    width: 80%;
    margin: 0 auto;
    padding: 25px 45px 45px 45px;  
    text-align: center;
    background: #0000008a;
    border-radius: 4px;
    max-height: 90%;
    overflow-y: auto;
    position: relative;
}
.simulation-description .simulation-message {
    position: absolute;
    width: calc(100% - 60px);
    height: auto;
    text-align: center;
    top: 30px;
    left: 30px;
    background: #4caf50;
    z-index: 10;
    display: flex;
    justify-content: center;
    flex-direction: column;
    font-size: 1.2rem;
    padding: 10px 0;
    margin-bottom: 20px;
}
.simulation-description .simulation-message i.las {
    font-size: 40px;
}
.simulation-description span.title-top {
    letter-spacing: 3px;
    margin: 10px;
    display: block;
    color: #ffffff94;
    text-transform: uppercase;
    font-size: 0.8rem;
}
.simulation-description h2 {
    font-weight: 800;
    font-size: 2.2rem;
}
.simulation-description > i.la {
    display: block;
    margin: 10px 0;
    font-size: 24px;
}
.simulation-actions {
    margin-top: 25px;
}
.simulation-actions a {
    min-width: 150px;
}
.finish .description.collapsed {
    display: flex;
    justify-content: space-between;
    flex-direction: row;
}
.finish .description p {    
    overflow: hidden;
    white-space: unset;
    text-overflow: unset;
    display: inline;
}
.finish .description.collapsed p {    
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.finish .description .more-link, .simulation-item .more-link {
    display: inline-block;
}
.finish .description.collapsed .more-link {
    color: #0069d9;
    min-width: 90px;
}
.finish .description .more-link, .simulation-item .more-link {
    color: #0069d9;
    min-width: 90px;
    margin-left: 5px;
}
.simulation-item .more-link {
    background: none !important;
    box-shadow: none;
    padding: 0;
    margin: 0;
    top: -8px;
    float: right;
    position: relative;
    text-align: right;
}
.simulation-student {
    padding: 5px;
}
.simulation-description .simulation-dates span {
    margin: 0 15px;
}
.simulation-description .simulation-dates span i {
    margin: 0 5px;
}
.simulation-cases-timeline, .simulation-status {
    margin-top: 25px !important;    
}
.simulation-cases-timeline .timeline-row {
    display: flex;
    flex-direction: row;
    justify-content: center;
    overflow-x: auto;
}
.simulation-cases-timeline.history .timeline-row {
    display: flex;
    flex-direction: column;
}
.simulation-cases-timeline.history .simulation-item {
    color: #1b2a4e;
    text-align: left;
    width: 100%;
    flex-direction: row;
}
.simulation-cases-timeline.history .item-header.background {   
    min-width: 200px;
}
/* Scroll descripcion */
.simulation-description::-webkit-scrollbar {
  width: 8px;
}
.simulation-description::-webkit-scrollbar-thumb {
  background: #000;
  border-radius: 4px;
}
.simulation-description::-webkit-scrollbar-thumb:active {
  background-color: #999999;
}
.simulation-description::-webkit-scrollbar-thumb:hover {
  background: #b3b3b3;
  box-shadow: 0 0 2px 1px rgba(0, 0, 0, 0.2);
}
 /* Estilos track de scroll */
.container::-webkit-scrollbar-track {
  background: #e1e1e1;
  border-radius: 4px;
}
.container::-webkit-scrollbar-track:hover, 
.container::-webkit-scrollbar-track:active {
  background: #d4d4d4;
}
.simulation-students {
    min-height: 200px;
}
.simulation-students .not-results, .overall.simulations .not-results {
    margin: 15px;
}
.simulation-students .simulation-students-table .simulation-item-header {    
    text-transform: uppercase;
    background: #f1f4f8;
}
.simulation-students .student-list-filter {
    position: absolute;
    left: 10px;      
    width: calc(100% - 30px);
}
.simulation-students .student-list-filter ul {
    list-style: none;
    padding-left: 20px;
}
.simulation-students .student-list-filter > label {
    background: #f1f4f8;
    padding: 5px; 
    width: 100%;
    color: #1b2a4e !important;
    text-transform: none;
}
.simulation-item .student-list-filter a {
    color: #2196f3;
    background: transparent !important;
    box-shadow: none !important;
    margin: 0;
    padding: 0;
}
.simulation-item .student-list-filter a:hover {
   
}
.simulation-students .student-list-filter .filters {
    padding: 5px; 
}
.simulation-students .student-list-filter .filters input[type="checkbox"] {
    position: relative;
    top: 1px;
    margin-right: 4px;
}
.simulation-students .student-list-filter .filters span {
    text-decoration: underline;
}
.simulation-students-table {
    display: table;
    width: 100%;
    z-index: 2;
    position: relative;
}
.simulation-students-table .simulation-item-header, .simulation-students-table .simulation-item-row {
    display: table-row;
}
.simulation-students-table .simulation-item-header div, .simulation-students-table .simulation-item-row div {
    display: table-cell;
    padding: 5px 10px;
    font-weight: normal;
}
.simulation-students-table .simulation-item-header div.name {
    border-left: 2px solid #fff
}
.simulation-item-row:nth-child(odd) {
    background: #f9fafc;
}
.simulations-bottom-actions {
    display: flex;
    justify-content: space-between;
    margin: 20px 0;
}
.btn-scroll-top {
    background: #0075fe;
    color: #fff;
    border: none;
    outline: none !important;
    font-size: 20px;
    height: 35px;
    line-height: 35px;
    border-radius: 0.25rem;
}
.simulation-students-table .simulation-item-header div {
    font-weight: 500 !important;
}
.finish .simulation-cases-timeline .timeline-row {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: left;
}
.finish .simulation-cases-timeline .timeline-row .simulation-item {
    width: calc(50% - 20px);
    max-width: calc(50% - 20px);
    display: flex;
    flex-direction: row;
    margin-bottom: 20px;
    min-width: calc(50% - 20px);
    margin: 10px 10px;
    flex: calc(50% - 20px);
}
.finish .simulation-cases-timeline .timeline-row .badge-status,
.finish .simulation-cases-timeline .timeline-row .item-date {
    display: none !important;
}
.finish .simulation-cases-timeline .timeline-row .item-header {
    width: 200px;
}
.finish .simulation-cases-timeline .timeline-row .item-body {
    max-width: calc(100% - 200px);
}
.simulation-cases-timeline > label {
    margin: 15px 0;
    letter-spacing: 3px;
    margin: 10px;
    display: block;
    color: #ffffff94;
    text-transform: uppercase;
    font-size: 0.8rem;
}
.simulation-cases-timeline .list-group-item.active {
    background-color: #0069d9;
    border-color: #0069d9;
    color: #fff;
}
.simulation-cases-timeline .list-group-item {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    color: #1b2a4e;
    overflow: hidden;
}
.simulation-cases-timeline .case-blur {
    position: absolute;
    width: 100%;
    height: 100%;
    background: #fff;
    top: 0px;
    left: 0px;
    filter: blur(16px);
    overflow: hidden;
}
.simulation-cases-timeline .list-group-item.header {
    background: #ffffff21;
}
.simulation-cases-timeline .list-group-item.header span {
    font-size: .8rem !important;
    font-weight: normal;
    text-transform: uppercase;
    height: auto;
    text-align: left;
    line-height: 1rem;
    color: #fff;
}
.simulation-cases-timeline .progress {
    height: 1.5rem;
    margin-top: 2px;
    border: 1px solid #d8d8d8;
}
.simulation-cases-timeline .progress.notstarted .progress-bar {
    width: 100% !important;
    color: #1b2a4e; 
    background: transparent;
}
.simulation-cases-timeline .list-group-item > span {
    padding: 0 10px;
}
.simulation-cases-timeline .case-order {
    border-radius: 50%;
    width: 26px;
    height: 26px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.simulation-cases-timeline .active .case-order {
     background: #ffffff2b;
}
.simulation-cases-timeline .case-order {
    background: #9282f11c;
}
.simulation-cases-timeline .case-score, .simulation-cases-timeline .case-attempts {
    width: 150px;
}
.simulation-cases-timeline .case-badge {
    width: 50px;
}
.simulation-cases-timeline span.case-name {
    width: calc(100% - 510px);
    text-align: left;
    font-size: .9rem;
    line-height: 1.5rem;
}
.simulation-cases-timeline .not-level {
    background: #f1f1f130;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.simulation-cases-timeline .not-level i {
    font-size: 40px;
    display: block;
    margin-bottom: 10px;
}
.simulation-cases-timeline .not-level span.case-name {
    width: 100%;
    text-align: center;
    color: #fff;
    padding: 0 10%;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.simulation-cases-timeline span.case-status {
    font-size: .9rem;
    margin: 0 !important;
    line-height: 1.5rem;
    width: 100px;
    text-align: left;
}
.simulation-cases-timeline .case-score span {   
    border-radius: 50%;
    width: 26px;
    font-weight: 800;
    height: 26px;
    display: inline-block;
    margin-left: 8px;
}
.simulation-cases-timeline .active .case-score span {
     background: #ffffff2b;
}
.simulation-cases-timeline .case-score span {
    background: #9282f11c;
}
.case-bottombar {
    position: absolute;
    bottom: 0;
    text-align: left;
    width: 100%;
    z-index: 9;
}
.case-help {
    width: 100%;
    margin: 0 auto;    
    background: #00000091;    
    text-align: left;
    -webkit-transition: all .5s ease-in-out;
    -moz-transition: all .5s ease-in-out;
    -ms-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    height: auto;
    max-height:600px;
    padding: 0;
    color: #fff;
    box-shadow: 0 0 10px 10px #ffffff14;
    font-size: 0.9rem;
    display: flex;
    justify-content: space-between;
    flex-direction: row;
}
.case-help > .col2, .case-help > .col1, .case-help > .col3 {
    display: inline-block;
    padding: 20px 30px;
    vertical-align: top;
}
.case-help > .col1 {
    min-width: 250px;
    display: flex;
    flex-direction: row;
}
.case-help > .col2 {
    min-width: calc(70% - 260px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.case-help > .col3 {
    padding-right: 10%;
    text-align: left;
}
label.upper-gray {
    text-transform: uppercase;
    font-size: 0.8rem;
    color: #ffffff8c;
    display: block;  
    margin-bottom: 0; 
}
.case-help .col2 label + span {
    margin-bottom: 10px;
    display: block;  
}
.case-help .case-help-score, .case-help .case-help-iteractions {    
    align-items: center;
    display: flex;
    justify-content: center;
    border: 12px solid #ffffff30;
    border-radius: 9999px;
    height: 100px;
    width: 100px;   
    position: relative;
}
.case-help .case-help-score + .curve, .case-help .case-help-iteractions + .curve {
    left: 0;
    position: absolute;
    top: 0;
    height: 100%;
    width: 100%;   
    /* If percentages is greater than or equals to 50 */
    clip: rect(auto, auto, auto, auto);
}
.case-help .case-help-score + .curve.less50, .case-help .case-help-iteractions + .curve.less50 {
    /* If percentages is less than 50 */
    clip: rect(0px, 100px, 100px, 50px);
}
.case-help .case-help-score + .curve .first, .case-help .case-help-iteractions + .curve .first {
    height: 100%;
    position: absolute;
    width: 100%;
    border: 12px solid rgb(66 186 150);
    border-radius: 9999px;
    clip: rect(0px, 50px, 100px, 0px);
    /*transform: rotate(162deg); Number of percentages * 360 / 100 */
}
.case-help .case-help-score + .curve .second, .case-help .case-help-iteractions + .curve .second {
    height: 100%;
    position: absolute;
    width: 100%;
    border: 12px solid rgb(66 186 150);
    border-radius: 9999px;
    /* Position */
    clip: rect(0px, 50px, 100px, 0px);
    /* If percentages is less than 50 */
    /*transform: rotate(0deg);*/
    /* If percentages is greater than or equals to 50 */
    transform: rotate(180deg);
}
.case-help .case-help-score + .curve .second.less50, .case-help .case-help-iteractions + .curve .second.less50 {
    transform: rotate(0deg);
}
.case-help .curve.warning .first, 
.case-help .curve.warning .second {   
    border: 12px solid #ffc107;
}
.case-help .curve.danger .first, 
.case-help .curve.danger .second {   
    border: 12px solid #df4759;
}
.case-help .col1 > label {
    position: absolute;
    font-size: 0.8rem;
    text-transform: uppercase;
    color: #ffffff8c;
    width: 70px;
    text-align: center;
}
/* Barra de casos izquierda */
.simulation-progress-bar .bar-item {
    position: relative;
    margin-bottom: 20px;
}
.simulation-progress-bar .bar-item-info {    
    align-items: center;
    display: flex;
    justify-content: center;
    border: 4px solid #ffffff30;
    border-radius: 9999px;
    height: 56px;
    width: 56px;   
    position: relative;
    box-shadow: 0 0 10px 10px #0000004a;
}
.simulation-progress-bar a {
    text-decoration: none !important;
    color: #fff !important;
}
.simulation-progress-bar a:hover .radial-progress {
    text-decoration: none;
    box-shadow: 0 0 10px 10px #000000d6;
}
.simulation-progress-bar .bar-item.current .first, .simulation-progress-bar .bar-item.current .second {
    border-color: #1976d259 !important;
}
.simulation-progress-bar .bar-item-info + .curve {
    left: 0;
    position: absolute;
    top: 0;
    height: 100%;
    width: 100%;   
    /* If percentages is greater than or equals to 50 */
    clip: rect(auto, auto, auto, auto);
}
.simulation-progress-bar .bar-item-info + .curve.less50 {
    /* If percentages is less than 50 */
    clip: rect(0px, 56px, 56px, 28px);
}
.simulation-progress-bar .bar-item-info + .curve .first {
    height: 100%;
    position: absolute;
    width: 100%;
    border: 4px solid rgb(66 186 150);
    border-radius: 9999px;
    clip: rect(0px, 28px, 56px, 0px);
    /*transform: rotate(162deg); Number of percentages * 360 / 100 */
}
.simulation-progress-bar .bar-item-info + .curve .second {
    height: 100%;
    position: absolute;
    width: 100%;
    border: 4px solid rgb(66 186 150);
    border-radius: 9999px;
    /* Position */
    clip: rect(0px, 28px, 56px, 0px);
    /* If percentages is less than 50 */
    /*transform: rotate(0deg);*/
    /* If percentages is greater than or equals to 50 */
    transform: rotate(180deg);
}
.simulation-progress-bar .bar-item-info + .curve .second.less50 {
    transform: rotate(0deg);
}
.simulation-progress-bar .bar-item .curve.warning .first, 
.simulation-progress-bar .bar-item .curve.warning .second {   
    border: 4px solid #ffc107;
}
.simulation-progress-bar .bar-item .curve.danger .first, 
.simulation-progress-bar .bar-item .curve.danger .second {   
    border: 4px solid #df4759;
}
.simulation-progress-bar .bar-item .case-title {
    display: none;
    position: absolute;
    padding: 5px;
    color: #fff;
    font-size: 11px;
    background-color: #464646;
    border-radius: 5px;
    top: 30px;
    min-width: 200px;
    left: 56px;
    width: auto;
    text-align: left;
}
.simulation-progress-bar .bar-item:hover .case-title {
    display: block;
}
.simulation-progress-bar .bar-item .case-title span {
    color: #ffc107;
}
.simulation-progress-bar .bar-item .case-title span.casename {
    text-decoration: underline;
    color: #fff;
}


.case-help .case-simulation-dates {
    font-size: .8em;
}
.case-help .case-simulation-dates span {
    margin-right: 20px;
}
.case-help .case-simulation-dates span i {
    margin: 0 5px;
}
.case-help .case-help-score i, .case-help .case-help-iteractions i {  
    margin-right: 5px;   
}
.case-help .case-help-score label, .case-help .case-help-iteractions label {  
    text-transform: uppercase;
    font-size: 0.7em;
    display: block;
    margin-bottom: 0;
    position: relative;
}    
.case-help .case-help-score span, .case-help .case-help-iteractions span {  
    font-size: 25px;
    line-height: 25px;
    position: relative;
}
.case-help.collapsed {
    max-height: 0;
    overflow: hidden;   
}
.case-help .breadcrumb {
    margin: 0;
    margin-bottom: 10px;
    font-size: 1em;
}
.case-help .case-description, .case-help .case-online-help {
    width: 100%;
}
.case-status {
    margin-bottom: 10px;
}
.case-help .badge {
    display: inline-block !important;
    font-size: .9rem;
    font-weight: normal;
    margin: 0;
    height: 28px;
    line-height: 21px;
    vertical-align: top;
    margin-right: 15px;
    margin-top: 5px;
}
.case-help .badge.finish {
    max-width: 180px;
}
.case-help .badge.hidden {
    display: none !important;
}
.case-help span.badge.badge-light {
    height: 20px;
    line-height: 15px;
    margin-right: 0;
    margin-left: 6px;
    margin-top: 0;
}
.case-help .case-name {
    font-weight: 700;
    font-size: 1.1rem;
}
.case-help .footer-chart-circle  {
    display: inline-block;
    padding: 0 10px;
    text-align: center;
}
.case-help .footer-chart-circle label {
    margin-bottom: 10px;
}
.case-help-icon {
    display: inline-block;
    font-size: 25px;
    padding: 0 10px;
    vertical-align: top;
    width: 60px;
    text-align: center;
    background: #000;
    margin-left: 5%;
    border-radius: 10px 10px 0 0;
    height: 30px;
}
.case-help-icon a {
    height: 32px;
    display: block;  
    color: #fff; 
}
.case-help-icon a i {
    vertical-align: top;
    padding: 4px;
}
.case-description {
    display: inline-block;    
    width: calc(100% - 100px);
    margin-bottom: 10px;
}
.case-help-toggle {
    width: 64px;
    height: 64px;
    position: absolute;
    bottom: 25px;
    left: 25px;
    z-index: 9;
    background: #ffffffeb;
    border-radius: 50%;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.case-help-toggle i {
    font-size: 45px;
}
.case-header {
    position: absolute;
    top: 20px;
    right: 30px;
    z-index: 10;
}
.case-header button i, .case-header a i {
    font-size: 25px;    
}
.case-action {
    display: inline-block;
    width: 82px;
    height: 82px;
    border-radius: 50%;
    background-color: #f93154;
    box-shadow: 0 3px 5px -1px rgb(0 0 0 / 20%), 0 6px 10px 0 rgb(0 0 0 / 14%), 0 1px 18px 0 rgb(0 0 0 / 12%);
    cursor: pointer;
    border: 0;     
    transition: all .5s;
    margin: 0 25px;   
    text-align: center; 
    position: relative;
}
.case-action.play:hover, .case-action.initplay:hover {
    background: #ec0029;
}
.case-video-footer .case-action.play {   
    position: relative; 
    top: unset;
    left: unset;
}
.case-action.audio {
     background-color: #f0ad4e;
}
.case-action.disabled, .case-action[disabled='disabled']  {
     background-color: #6c757d;
}
.case-number {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #f93154;
    box-shadow: 0 3px 5px -1px rgb(0 0 0 / 20%), 0 6px 10px 0 rgb(0 0 0 / 14%), 0 1px 18px 0 rgb(0 0 0 / 12%);
    cursor: pointer;
    border: 0;   
    transition: all .5s;
    line-height: 20px;
    text-align: center;
    background-color: #ffffff33;
    color: #ffffff52 !important;
    vertical-align: top;
}
.case-number.active {
    background-color: #f44336d4;
    color: #fff !important;
}
.case-number.finished {
    background-color: #42ba96; 
    color: #222 !important;
}
.case-number.finished.normal {
    background-color: #ffc107; 
    color: #222 !important;
}
.simulation-progress > div {
    display: inline-block;
    vertical-align: top;
}
.simulation-progress label i {
    margin-right: 6px;
}
.simulation-progress .simulation-cases-progress, .simulation-progress .simulation-score-progress {
    display: inline-block;
    margin: 0 15px;
    width: calc(49% - 30px);   
}
.simulation-score-progress .bar {
    min-width: calc(100% - 230px);
}

.case-action:hover span, .case-number:hover span {
    display: block;
}
.case-action span {
    display: none;
    position: absolute;
    padding: 5px;
    color: #fff;
    font-size:.9rem;
    background-color: #464646;
    border-radius: 5px;
    left: 82px;
    width: 150px;
    top: 0;
    z-index: 7;
}
.case-action.initplay span {
    left: 100px;
    top: unset;
}
.case-number span {
    display: none;
    position: absolute;
    padding: 5px;
    color: #fff;
    font-size: 11px;
    background-color: #464646;
    border-radius: 5px;
    top: 30px;
    min-width: 200px;
    width: auto;
}
.case-action.initplay {
    position: relative; 
    width: 100px;
    height: 100px;
    margin: 0 auto;
}
.case-action i {
    font-size: 42px;
    line-height: 82px;
    color: #fff;
}
.case-action.initplay i {
    font-size: 60px;
    line-height: 100px
}
.case-header .speed-dial__button--root {
    color: #fff;
}
.case-header button {
    outline: none;    
}
.simulation-header {
    height: 90px;
    position: relative;
    text-align: center;
}
.simulation-progress {
    width: 60%;
    min-width: 500px;
    position: relative;    
    top: 0;
    z-index: 9;
    background: #000000bd;
    padding: 8px 60px;
    color: #fff;
    font-size: 0.8em;
    text-transform: uppercase;    
    padding-right: 40px;
    height: 35px;
    display: inline-block;
}
.simulation-progress .progress {
    background: #e9ecef;
    height: 18px;   
}
.simulation-progress > div {
    display: inline-block;
}
.simulation-progress label {
    margin: 0;
    margin-right: 10px;
    min-width: 175px;
}
.simulation-progress .label + div {
    display: inline-block;
    position: relative;
    top: -2px;
}
.simulation-progress div.label {
    min-width: 165px;
    display: inline-block;
    line-height: 20px;
}
.simulation-progress div.label i {
    font-size: 30px;
    position: relative;
    top: -5px;
    color: #42ba96;
    float: left;
}
.simulation-progress > div.bar {
    width: calc(100% - 168px);
    top: -1px;
    position: relative;
}
.simulation-progress:after {
    content: "";
    width: 30px;
    height: 35px;
    position: relative;
    position: absolute;
    right: -35px;
    top: 0;
    border-top: 35px solid #000000bd;
    border-right: 35px solid transparent;
}
.simulation-progress:before {
    content: "";
    width: 30px;
    height: 35px;
    position: relative;
    position: absolute;
    left: -35px;
    top: 0;
    border-top: 35px solid #000000bd;
    border-left: 35px solid transparent;
}
.progress-bar {   
    transition: width 2.0s ease;
}

/* Video background */
#player {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.video-background {
    background: #000;
    position: fixed;
    top: 0; right: 0; bottom: 0; left: 0;
    z-index: -99;
}
.video-foreground,
.video-background iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}
@media (min-aspect-ratio: 16/9) {
    .video-foreground { height: 300%; top: -100%; }
}
@media (max-aspect-ratio: 16/9) {
    .video-foreground { width: 300%; left: -100%; }
}
@media all and (max-width: 600px) {
    .vid-info { width: 50%; padding: .5rem; }
    .vid-info h1 { margin-bottom: .2rem; }
}
@media all and (max-width: 500px) {
    .vid-info .acronym { display: none; }
}

.video-poster {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%; 
    background-repeat: no-repeat;
    background-size: cover !important;
    background-position: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.video-poster.played .case-action {
    display: none;
}
#player iframe { 
  pointer-events: none;
}
.default-label-gray {
    margin-bottom: 10px;
    text-transform: uppercase;    
    color: #1b2a4e8c;
    display: block; 
}
.stepsbar > label, label.top-center-label {
    margin-bottom: 10px;
    text-transform: uppercase;    
    color: #1b2a4e8c;
    display: block; 
    font-size: .8em;
}
label.top-center-label.white {
    color: #ffffff94;
}
.stepsbar .step {
    height: auto;
    position: relative;
    display: inline-block;
    min-width: 200px;
    text-align: center;
    padding: 5px 20px;
}
.stepsbar .step span {
    background: #007bff;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    color: #fff;
    display: inline-block;
    text-align: center;
    font-size: 22px;
    line-height: 32px;
}
.stepsbar .step.finish span {
    background: #42ba96;
}
.stepsbar .step label {   
    display: block;
    margin-top: 5px;
    margin-bottom: 0;
}
.stepsbar .step p {   
    display: block;
    margin: 0 0 0 35px;
    font-size: .8em;
}
.step.step.current:after {
    content: "";
    position: absolute;
    height: 100%;
    background: #ffffff61;
    width: 100%;
    left: 0;
    top: 0;
}
.modal-dialog .step.step.current:after {
    background: #0069d924;
}
.modal-dialog .step.step.current:after {   
    height: 26px;
    border-radius: 0;
}
.modal-dialog .stepsbar > label {
    margin: 30px 0 15px 0;
    background: #f5f5f5;
    padding: 4px;
}
.modal-dialog .stepsbar .step {
    height: 70px;
}
.modal-dialog .stepsbar .step label {
    vertical-align: middle;
}
.modal-dialog .stepsbar {
    background: #fff;
    margin-left: -1rem;
    margin-right: -1rem;
    margin-bottom: -1rem;
}   
.case-video-footer {
    position: absolute;
    background: #000000;
    width: 100%;
    height: 175px;
    bottom: 0;
    z-index: 8;
    -webkit-transition: all .5s ease-in-out;
    -moz-transition: all .5s ease-in-out;
    -ms-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    display: none;
    box-shadow: 1px 0px 14px 14px #000000ed;
    padding-top: 35px;
    text-align: center;
    display: none !important;
}
.case-audio-front, .case-finish-front, .simulation-front {
    position: absolute;
    background: #00000066;
    height: 100%;
    width: 100%;
    top: 0;
    display: none;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 10%;
    color: #fff;
    z-index: 8;   
}
.simulation-front {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 0;
}
.case-finish-front.hidden {
    display: none !important;
}

/* Condicionales */ 
.case-root.expert .on-expert, .case-root.normal .on-normal {
    display: block;
}
.case-root.has-attempts .on-hasattempts {
    display: inline-block;
}
.case-root.not-attempts .on-not-hasattempts {
    display: inline-block;
}
.display-on {
    display: none;
}
.case-root.has-attempts .on-hasattempts {
    display: inline-block;
}
.case-root.lastcase .btn-repeat {
    display: none;
}
.case-root.lastcase .on-not-lastcase {
    display: none;
}
.case-root.not-lastcase .on-not-lastcase {
    display: flex;
}
.case-root.video-played .on-video-played {
    display: block;
}
.case-root.case-completed .on-case-completed {
    display: block;
}
.case-root.case-notcompleted .on-case-notcompleted {
    display: block;
}

.front-message {
    position: absolute;
    width: 100%;
    text-align: center;
    background: #de2c4bd1;
    left: 0;
    top: 0;
    padding: 3rem;
    height: 100%;
    z-index: 9;
    flex-direction: column;
    justify-content: center;
    color: #fff;
    display: none;    
}
.front-message h1 {
    font-weight: 700;
}
.front-message p, .front-message label {
    font-size: 1.1rem;
}
.front-message.init {
    background: #467fd0d1;
}
.front-message i.separator {
    font-size: 24px;
    margin-top: 10px;
    margin-bottom: 30px;
}
.front-message.init i.front-icon {
    background: #467fd0;
}
.front-message .front-message-dialog-centered {
    margin: 0 auto;
}
.front-message i.front-icon {
    font-size: 60px;
    background: #bd2740;
    font-size: 60px;
    color: #fff;
    display: none;
    font-size: 60px;
    border-radius: 50%;
    margin: 0 auto;
    margin-bottom: 30px;
    padding: 21px;
    box-shadow: 0 0 8px 3px #00000033;
    transition: 1.5s all ease;
    position: relative;
    width: 102px;
    overflow: hidden;
}
.front-message .front-message-footer {
    margin-top: 50px;
}
.front-message .front-message-box {
    background: #ffffff14;
    padding: 30px;
    border-radius: 10px; 
}
.front-message.init .on-init-front, .front-message.error .on-error-front, .front-message.success .on-success-front, 
.front-message.repeat .on-repeat-front, .front-message.video-finish .on-video-finish-front {
    display: block;
}
.front-message.success, .front-message.video-finish {
    background: #4caf50d1;
} 
.front-message.success i.front-icon, .front-message.video-finish i.front-icon {
    background: #4caf50;
}

.case-video-toggle-top .case-action, .case-audio-actions .case-action {
    width: 56px;
    height: 56px;
    margin: 20px 0;
    margin-top: 0;
    display: block;
}
.case-audio-actions .case-action {
    margin-top: 0;
}
.case-video-toggle-top .case-action.disabled, .case-audio-actions .case-action.disabled {
    background-color: #5a5959;
    cursor: initial;
}
.case-video-toggle-top .case-action i, .case-audio-actions .case-action i {
    line-height: 56px;
}
.record-actions {
    margin-bottom: 25px;
}
.record-actions #confirm {
    display: none;
}
.case-audio-front div.micro > i {
    font-size: 60px;
    border-radius: 50%;
    margin-bottom: 30px;
    padding: 21px;
    box-shadow: 0 0 10px 10px #00000082;
    transition: 1.5s all ease;
    position: relative;
    width: 102px; 
}
.case-audio-front .la-microphone {
    background: #f93154;
}
.case-audio-front.disabled .la-microphone {
    background: #6c757d;
}
.case-audio-front.actived .la-microphone.recording {
    background: #ec0029;
}
.case-audio-front .la-thumbs-up, .case-audio-front .la-save {
    background: #4caf50 !important;
}
.case-audio-front .la-cloud-upload-alt {
    background: #ff9800 !important;
}
#microphoneicon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background: #0000001c;
    width: 100%;
    height: 100%;
    z-index: 0;
    display: block;
    transition: all 8s;
}
#microphoneicon.loading.la-cloud-upload-alt::after {
    top: -120px;
}
#confirmActions {
    padding: 50px 0;
    font-size: 1.1rem;
    display: none;
}
#confirmActions i {
    color: #4caf50;
    font-size: 60px;
}   
.pulse-ring {
  content: '';
  width: 114px;
  height: 114px;
  border: 15px solid #ec0029;
  border-radius: 50%;
  position: absolute;
  top: -6px;
  left: -6px;
  animation: pulsate infinite 2s;
  display: none;
}
.pulse-ring-sidebar {
  content: '';
  width: 66px;
  height: 66px;
  border: 15px solid #ec0029;
  border-radius: 50%;
  position: absolute;
  top: -5px;
  left: -5px;
  animation: pulsate infinite 2s;
  display: none;
}
.recording .pulse-ring, .recording .pulse-ring-sidebar {
    display: block;
}
@-webkit-keyframes pulsate {
  0% {
    -webkit-transform: scale(1, 1);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.2, 1.2);
    opacity: 0;
  }
}
.modal-dialog.error .modal-error-box {
    color: #f44336;
    margin: 10px;
}
.modal-dialog.error .modal-header, .modal-dialog.error .modal-footer {
    background: #f4433612;
}
.modal-dialog.success .modal-header, .modal-dialog.success .modal-footer {
    background: #4caf501f;
}
.modal-dialog .modal-body > i {
    font-size: 45px;
}
.video-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 6;
    display: none;
}
#feedbackScore, #caseRepeat {
    width: 50%;
    margin: 30px auto;
}
#feedbackScore .progress, #caseRepeat .progress {
    font-size: 1rem;
    height: 2rem;
    background-color: #f0f1f3;
}
/*.bs-tooltip-auto[x-placement^=top] .arrow:before, .bs-tooltip-top .arrow:before {
    border-top-color: #ffffff;
}
.bs-tooltip-auto[x-placement^=left] .arrow:before, .bs-tooltip-left .arrow:before {
    border-left-color: #ffffff;
}
.bs-tooltip-auto[x-placement^=right] .arrow:before, .bs-tooltip-right .arrow:before {
    border-right-color: #ffffff;
}
.bs-tooltip-auto[x-placement^=bottom] .arrow:before, .bs-tooltip-bottom .arrow:before {
    border-bottom-color: #ffffff;
}*/
.tooltip.show {
    opacity: 1;
    left: -4px;
}
.tooltip-inner {    
    /*color: #000;
    background-color: #ffffff;*/
    border-radius: 10px;
    position: relative;
    padding: 15px;
}
.tooltip-inner i.las, .tooltip-inner i.lar {
    display: none;
    font-size: 30px;
    color: #4caf50;    
}
.tooltip-inner i.la-exclamation-triangle {
    color: #ec0029;
}
.tooltip .tooltip-inner a {
    cursor: pointer;
    position: absolute;
    top: 0px;
    right: 8px;
    font-size: 1.2rem;
    display: none;
}
.tooltip.bs-tooltip-left .tooltip-inner a {
    left: 8px;
    right: unset;
}
#caseHelp div i.las {
    display: block;
    margin-bottom: : 20px;
    font-size: 42px;
    display: none;
}
#feedbackText {
    font-weight: 700;
}
.case-finish-front .la-thumbs-up {
    background: #42ba96;
    font-size: 40px;
    color: #fff;   
    display: inline-block;
    border-radius: 50%;
    margin: 0 auto;
    margin-bottom: 30px;    
    box-shadow: 0 0 10px 10px #00000082;
    transition: 1.5s all ease;
    position: relative;
    width: 65px;   
    height: 65px;
    line-height: 65px; 
    overflow: hidden;
}
.case-finish-front.normal .la-thumbs-up {
    background: #ffc107;
}
.case-finish-front .bar {
    margin: 0 auto;
}
.case-finish-front .bar .progress {
    height: 2rem;   
    width: 100%;
}
.case-finish-front .bar .bar-2col. {
    width: 310px;
    display: inline-block;
    margin: 0 10px;
}
.simulation-description .bar .bar-2col {
    width: 45%;
    display: inline-block;
    margin: 0 10px;
}
#playerTimeBarProgress, #playerTimeBarProgress + .viewed {
    position: absolute;
    top: 0;
    left: 0;
    height: 5px;
    z-index: 9;
    width: 0;
    background: #1976d2;
}
.simulation-progress-bar .bar-item {
    position: relative;
    margin-bottom: 20px;
    color: #fff;
}    
.simulation-progress-bar {
    position: absolute;
    left: 30px;
    top: 20px;
    z-index: 10;
}

/* Columna de intentos de un caso */
#userAttempts .progress {
    height: 20px;
    width: 100%;
    min-width: 115px;
}
#userAttempts .attempts-table-body .attempt-row {
    display: flex;
    justify-content: space-between;
    flex-direction: row;
}
#userAttempts .attempts-table-body {
    margin-top: 10px;
}
#userAttempts .row-score {
    min-width: 115px;
}
#userAttempts .row-num {
    min-width: 50px;
}
#userAttempts .row-date {
    min-width: 135px;
}
#userAttempts .row-help a {
    font-size: 1.5rem;
    line-height: 20px;
    position: relative;
    top: -2px;
    color: #fff;
}  
#userAttempts .progress-bar {
    color: #222;
}
#userAttempts .attempts-table-body .attempt-row {
    width: 100%;
    margin-bottom: 2px;
    font-size: 0.8rem;
}
#userAttempts .attempts-table-body .attempt-row > div {
    display: inline-block;
    vertical-align: middle;
    padding-right: 20px;
}
#userAttempts .attempts-table-body .attempt-row > div:last-child {
   text-align: right;
}
#userAttempts .row-date i {    
    margin-right: 5px;
}
#continueSection {
    margin: 50px;
}
#continueSection > h1, .case-finish-front h1 {
    font-weight: 700;
}
.case-finish-front > p  {
    font-size: 1.1rem;
}
#continueSection > h1 + div  {
    margin: 35px 0;
    font-size: 1.1rem;
}
#continueSection > h1 + div span, .case-finish-front p span {
    color: #1976d2;
}
.simulation-footer .case-help .case-guide {
    font-size: 0.9rem;
}
.simulation-footer .case-help .case-guide .step {
    margin-top: 10px;
}
.simulation-footer .case-help .case-guide .guide-steps {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

/* Loading spinner */
#ajaxLoading {
    display: none;
}
.spinner {
  width: 40px;
  height: 40px;
  position: relative;
  margin: 20px auto;
}

.double-bounce1, .double-bounce2 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #fff;
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;  
  -webkit-animation: sk-bounce 2.0s infinite ease-in-out;
  animation: sk-bounce 2.0s infinite ease-in-out;
}

.double-bounce2 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}

@-webkit-keyframes sk-bounce {
  0%, 100% { -webkit-transform: scale(0.0) }
  50% { -webkit-transform: scale(1.0) }
}

@keyframes sk-bounce {
  0%, 100% { 
    transform: scale(0.0);
    -webkit-transform: scale(0.0);
  } 50% { 
    transform: scale(1.0);
    -webkit-transform: scale(1.0);
  }
}

#helpBubble {
    position: relative; 
    width: 100%;
    text-align: center;
    z-index: 9;    
    color: #1b2a4e;
    margin-bottom: 20px;
    cursor: pointer;
}
#helpBubble img {
    max-width: 56px;
    position: relative;
}
.bubble
{
   position: absolute;
   width: auto;
   min-width: 250px;
   max-width: 450px;
   height: auto;
   padding: 10px;
   background: #ffffff;
   -webkit-border-radius: 10px;
   -moz-border-radius: 10px;
   border-radius: 10px;
   border: #000 solid 1px;
   font-size: 0.9rem;
   margin: 0 auto;
   display: block;
   right: 65px;
}

.bubble:after
{
    content: '';
    position: absolute;
    border-style: solid;
    border-width: 8px 0 8px 8px;
    border-color: transparent #ffffff;
    display: block;
    width: 0;
    z-index: 1;
    right: -8px;
    top: 12px;
}

.bubble:before
{
    content: '';
    position: absolute;
    border-style: solid;
    border-width: 8px 0 8px 8px;
    border-color: transparent #D6D2D2;
    display: block;
    width: 0;
    z-index: 0;
    right: -9px;
    top: 12px;
}

/* Dashboard */
.transparent .card {
    background: transparent;
    border: none;
    box-shadow: none;
}
.transparent .card .card-header {
    background: #fff;
    border: 1px solid #d9e2ef;
}
.dashboard-simulations {
    display: flex;
    overflow: hidden;
    overflow-x: auto;
}
/* Scroll descripcion */
.dashboard-simulations::-webkit-scrollbar {
  width: 8px;
}
.dashboard-simulations::-webkit-scrollbar-thumb {
  background: #e7ecf3;
  border-radius: 4px;
}
.dashboard-simulations::-webkit-scrollbar-thumb:active {
  background-color: #999999;
}
.dashboard-simulations::-webkit-scrollbar-thumb:hover {
  background: #b3b3b3;
}
.dashboard-simulations::-webkit-scrollbar-track {
  background: #e1e1e1;
  border-radius: 4px;
}
.dashboard-simulations::-webkit-scrollbar-track:hover, 
.dashboard-simulations::-webkit-scrollbar-track:active {
  background: #d4d4d4;
}
.simulation-item {
    position: relative;
    display: flex;
    width: calc((100% - 40px) / 3);
    min-width: calc((100% - 40px) / 3);
    background: #fff;
    border: 1px solid #d9e2ef;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 5%);
    vertical-align: top;
    margin-right: 20px;
    margin-top: 20px;    
}
.dashboard-simulations .simulation-item {
    flex-direction: column;
    justify-content: space-between;
}
.simulation-description .simulation-item {
    color: #1b2a4e;
    text-align: left;
    width: calc(100% / 5);
    min-width: calc(100% / 5);
    max-width: calc(100% / 5);
    border: 1px solid #6b6b6b;
    display: flex;
    flex-direction: column;
}
.simulation-description .simulation-status {
    margin-bottom: 10px;
    background: #00000078;
    width: calc(100% + 90px);
    margin-left: -45px;
    margin-right: -45px;
    position: relative;
    padding-bottom: 10px;
}
.simulation-description .simulation-status .progress {
    height: 25px;
    font-size: 1rem;
}
.simulation-description .simulation-status .progress .progress-bar {
    color: #000;
}
.simulation-description .simulation-status .progress .progress-bar span {
    padding: 0 6px;
}
.dashboard-simulations.more3 {    
    overflow-x: scroll;
}
.dashboard-simulations.more3 .simulation-item {
    width: calc((100% - 110px) / 4);
    min-width: calc((100% - 110px) / 4);
}
.simulation-item.empty {
    background: #e7ecf3;
}
.simulation-item:last-child {
    margin-right: 0;
}
.item-header.background {
    background-size: cover;
    background-position: center;
    padding-top: 2rem;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 32%);
    min-height: 110px;
    max-height: 170px;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    background-color: #d8d8d8;
    align-items: flex-end;
}
.simulation-item .item-body {
    padding: 10px;
    font-size: .9rem;
    padding-bottom: 0;
    /*display: flex;*/
    padding-bottom: 0;
    /*flex-direction: column;
    justify-content: space-between; 
    align-items: flex-start;  */
}
.simulation-body .overall-return {
    position: absolute;
    right: 30px;
}
.simulation-body .overall-return a {
    color: #fff;
    font-size: 30px;
}
.timeline-row .simulation-item .item-body {   
    /*align-items: flex-start;*/
}
.simulation-item .item-body .item-help, .simulation-footer .col3 .item-help {
    background: #ffeb3b;
    padding: 0 5px;
    margin-top: 6px;
    font-weight: bold;
    line-height: 25px;
}
.simulation-item .item-body .item-help img {
    margin-right: 6px;
    border: 1px solid #d0bb00;
    border-radius: 50%;
    max-width: 20px;
}
.simulation-item .item-body .item-help label {
    text-decoration: underline;
}
.simulation-cases-timeline .simulation-item .item-body {
    padding-bottom: 10px;
}
.simulation-cases-timeline .simulation-item .item-body .item-date {
    display: block;
    margin-top: 3px;
    font-size: .8rem;
}
.simulation-item .item-body .item-other-data {
    margin-top: 8px;
    align-self: flex-end;
}
.simulation-item .item-body .item-other-data span {
    margin: 0;
}
.simulation-item .item-body .item-other-data a,
.simulation-item .item-body .item-other-data span span {
    background: none;
    box-shadow: none;
    text-decoration: none;
    color: inherit;
    margin: 0;
    padding: 0;
    font-size: 18px;
    border-radius: 4px;
    text-align: center;
    min-width: 32px;
    display: inline-block;
    background: #1976d22b;
    color: #1976d2;
    padding: 0 8px;
}
.simulation-item .item-body .item-other-data a:hover {
    background: #1976d24b;
}
.simulation-item .item-body .item-other-data a i,
.simulation-item .item-body .item-other-data span i {
    margin-right: 0;
}
.simulation-item .item-body .item-other-data .repeats i {
    font-size: 16px;
}
.simulation-item .item-body .status-and-actions {
    display: flex;
    justify-content: space-between;
    vertical-align: top;
}
.simulation-item .item-body .status-and-actions .item-other-data {
    margin-top: 0;
}
audio::-webkit-media-controls-play-button,
audio::-webkit-media-controls-panel {
    background-color: #fff;
}
.other-data-overlay {
    position: absolute;
    top: 0;
    left: 0;
    background: #fff;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    display: none;
    justify-content: flex-start;   
    display: none;
    padding: 20px 20px 50px 20px;
    z-index: 10;
}
.other-data-overlay span {
    align-self: flex-end;
}
.other-data-overlay audio { 
    max-width: 80%;
    padding: 6px;
    margin-top: 50px;
}
.other-data-overlay div.help-content { 
    padding-top: 25px;
    font-size: .9rem;
    line-height: 1rem;
}
.other-data-overlay label { 
    font-weight: 600;
    padding-bottom: 10px;
    position: absolute;
    left: 20px;
}
.simulation-cases-timeline .simulation-item {
    margin-top: 0;
}
.simulation-item .item-body .name {
    font-weight: 700;
    display: block;
}
.simulation-item .item-body .name a {
    background: none;
    color: inherit;
    box-shadow: none;
}
.simulation-item .item-body .name a i {
    margin-left: 4px;
    font-size: 18px;
    color: #2196f3;
    display: inline;
    text-decoration: none;
    position: relative;
    top: 1px;
}
.simulation-item .item-body .simulation-status .badge {
    font-size: .9rem;
    padding: 4px 8px;
}
.simulation-item .item-body .field-row span:first-child {
    margin-right: 10px;
}
.simulation-item .item-body .field-row {
    margin: 5px 0;
}
.simulation-item .item-body .description {
    display: block;    
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: .9rem;
    margin-bottom: 8px;
}
.simulation-item .item-body .status {
    margin-top: 10px;
    background: #f1f4f85e;
    padding: 10px;
    margin-left: -10px;
    margin-right: -10px;
    min-height: 40px;
}
.simulation-item .item-body .status span {
    font-size: .8rem;
}
.simulation-item .item-header .score {
    margin: 10px;
    width: 100%;
}
.simulation-item .item-header .score .progress {
    background: #f9fbfdc7;   
    height: 18px;
    font-size: .85rem;
    font-weight: 600; 
    opacity: .8;
}
.simulation-item .item-header .score .progress .progress-bar {
    color: #1b2a4e;
}
.simulation-item .item-header .score .progress .progress-bar span {
    padding: 0 5px;
}
.simulation-item a {    
    box-shadow: 0 1px 3px 0px rgb(14 14 14 / 32%);
    border-radius: 0;
    padding: 2px 15px;
    color: #fff;
    margin-right: 10px;
    text-decoration: none;
    transition: background-color 0.5s ease;
    background: #2196f3d9;
    font-size: .9rem;
}
.simulation-item a.icon {
    background: none;
    box-shadow: none;
    color: #2196f3;
    font-size: 20px;
    line-height: 20px;
    display: inline;
    padding: 4px;
    position: relative;
    top: 2px;
}
.simulation-item a:hover { 
    background: #2196f3;
}
.simulation-item a.icon:hover {
    background: none;
    color: #006cc1;
}
.simulation-item a.init {
    background: #2196f3d9;   
}
.simulation-item a.continue {
    background: #ff9800d9;   
}
.simulation-item a.init:hover {
    background: #2196f3;
}
.simulation-item a.continue:hover {
    background: #ff9800;  
}
.simulation-item a i {
    margin-right: 6px;
}
.dashboard-simulations .not-results {
    width: 100%;
    text-align: center;
    padding: 30px;
    background: #e7ecf3;
    border: 1px solid #d9e2ef;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 5%);
    margin: 20px 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.dashboard-ranking .docs a {
    font-size: .9rem;
}
.dashboard-ranking .docs i {
    font-size: 1.2rem;
}
.dashboard-ranking, .dashboard-badges {
    margin: 20px 0;
}
.dashboard-ranking, .dashboard-badges {
    border: 1px solid #d9e2ef;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 5%);
    background: #e7ecf3;    
}
.dashboard-ranking.not-ranking, .dashboard-badges.not-badges {
    display: flex;
    justify-content: center;
    align-items: center;
}
.dashboard-ranking .img-avatar, .dashboard-badges .img-avatar {
    height: 28px;
    margin: 0 15px;
}
.dashboard-ranking .ranking-avatar, .dashboard-badges .badge-avatar {
    width: 58px;
}
.dashboard-ranking .ranking-data, .dashboard-badges .badge-data {
    width: calc(100% - 58px);
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}
.dashboard-ranking .ranking-item, .dashboard-badges .badge-item {
    display: flex;
    flex-direction: row;
    padding: 10px 5px;
    border-bottom: 1px solid #d9e2ef;
    background: #fefefe;
    line-height: 27px;
}
.dashboard-ranking .ranking-item:first-child {
    background: #C9B03721;
}
.dashboard-ranking .ranking-item:nth-child(2) {
    background: #D7D7D721;
}
.dashboard-ranking .ranking-item:nth-child(3) {
    background: #AD8A5621;
}
.dashboard-ranking .ranking-item:last-child, .dashboard-badges .badge-item:last-child {
    /*border-bottom: none;*/
}
.dashboard-ranking .ranking-data .score {
    width: 60px;
    font-weight: 600;
}
.dashboard-ranking .ranking-data .name, .dashboard-badges .badge-data .name {   
    font-size: .9rem;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    width: calc(100% - 60px);
    max-width: calc(100% - 60px);
}
.dashboard-badges .badge-data .name.has-last {     
    width: calc(100% - 90px);
    max-width: calc(100% - 90px);
}
.dashboard-ranking .ranking-data .name.has-percent, .dashboard-badges .badge-data .name.has-last {
    position: relative;
    margin-top: -7px;
}
.dashboard-ranking .ranking-item .score:before {
    font-family: 'Line Awesome Free';
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    content: "\f559";
    opacity: 0;
    margin-right: 8px;
    font-size: 1.2rem;
    top: 2px;
    position: relative;
}
.dashboard-ranking .ranking-item:first-child .score:before,
.dashboard-ranking .ranking-item:nth-child(2) .score:before,
.dashboard-ranking .ranking-item:nth-child(3) .score:before {
    opacity: 1;
}
.dashboard-ranking .ranking-item:first-child .score:before {
    color: #C9B037;
}
.dashboard-ranking .ranking-item:nth-child(2) .score:before {
    color: #bbb7b7;
}
.dashboard-ranking .ranking-item:nth-child(3) .score:before {
    color: #AD8A56;
}
.dashboard-ranking .percent-bottom, .dashboard-badges .last-bottom {
    position: absolute;
    left: 0;
    top: 16px;
    font-size: .75rem;
    min-width: 150px;
}
.overall.simulations form {
    background: #f9fafd;
    padding: .5rem 2rem 0 2rem;
}
.overall.simulations form .form-group {
    margin-bottom: .5rem;
}
.overall.simulations form .form-row {
    justify-content: center;
    flex-direction: row;
    align-items: center;
}
.overall.simulations form .form-check-inline {
    position: relative;
    top: 2px;
}
.overall.simulations form .form-check-label {
    color: #0069d9;
}
.overall.simulations form label {
    margin-bottom: 0;
}
.simulation-item .item-header.background .order {
    position: absolute;
    top: 0;
    color: #fff;
    left: 0;
    background: #0000009c;
    padding: 0 10px;
}
.simulation-item .item-body .badge {
    font-size: 0.8rem;
    font-weight: normal;
    margin: 0;
}
.simulation-item .item-body label {
    color: gray;
    display: inline-block;
    margin-right: 8px;
    margin-bottom: 0;
}
.simulation-item .item-body span.value {
    font-weight: 600;
    display: inline-block;
}
.simulation-item .item-body span.value-circle {
    background: #80808030;
    border-radius: 4px;
    width: 16px;
    display: inline-block;
    text-align: center;
    padding: 0;
    line-height: 16px;
}
.simulation-item .item-body .incomplete {
    color: #ff5722;
    display: inline-block;
}
.simulation-item .item-body .incomplete i {
    font-size: 20px;
    position: relative;
    top: 2px;
}
.simulation-item .item-body span.value span {
    font-weight: normal;
}
.simulation-item .item-body .field-icon span i {
    margin-right: 6px;
}
.simulation-item .item-edit {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    max-height: 0;
    justify-content: center;
    flex-direction: row;
    text-align: center;
    background: #e7ecf3d9;
    display: flex;
    transition: 1s all;
    overflow: hidden;
    font-size: 0.9rem; 
    z-index: 9;
}
.simulation-item:hover .item-edit {
    max-height: 100px;
}
.simulation-item .item-edit a {
    display: block;
    margin: 0 auto;
    padding: 10px 20px;
    margin: 0 auto;
    padding: 5px 5px;
    margin: 10px 15px;
}

/* Widget top */
#statusWidget {
    display: inline-block;
    z-index: 999999;
    position: relative;
    color: #fff;
    background: #0000004d;
    padding: 0;
    border-radius: 33px;
    height: 50px;
    line-height: 43px;    
    padding: 4px 6px;
    transform: translateY(-50px);
    animation-duration: 1s;
    animation-fill-mode: both;
    overflow: hidden;
}
#statusWidget.repeat {
    background: #f93154;
}
#statusWidget.finish {
    background: #42ba96;
}
#statusWidget .widget-content {
    display: flex;
    justify-content: space-between;
    flex-direction: row;
}
#statusWidget .widget-left {
    background: #ffffff33;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    z-index: 2;
    position: relative;
}
#statusWidget .widget-right {
    background: #ffffff33;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    z-index: 2;
    position: relative;
    transition: .5s all;
    opacity: 0;
}
#statusWidget .widget-left i, #statusWidget .widget-right i {
    font-size: 20px;
    line-height: 42px;
}
#statusWidget .widget-center {
    padding: 0 30px;
    z-index: 2;
}
#statusWidget .widget-center label {
    opacity: 0;    
    white-space: nowrap; 
    margin: 0 auto; 
    letter-spacing: 1px; 
}
#statusWidget .widget-center span {
    opacity: 0;
    display: block;     
    position: absolute;
    top: 0;
    line-height: 50px;
    margin: 0;
    text-align: left;   
}
#statusWidget .widget-center span.typing {
    opacity: 1;   
    overflow: hidden; 
    white-space: nowrap; 
    margin: 0 auto; 
    letter-spacing: 1px; 
    /*animation: typing 3.0s steps(40, end);  */   
}
#statusWidget .widget-progress {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: #000;
    z-index: 1;
    transition: all 5s;
    width: 0;
}
#statusWidget.finish .widget-right {
    background: #42ba96;
}
#statusWidget.finish .widget-progress {
    display: none;
}

.fadeTopBottom { animation-name: fadeTopBottom }
@keyframes fadeTopBottom {
    from {
        opacity: 0;        
    }
    to { opacity: 1; transform: translateY(30px); }
}
@keyframes typing {
    from { width: 0 }
    to { width: 100%; }
}

/* Counter */
div.counter {
    color: #fff;
    font-size: 100px;
    display: block;
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 9;
    top: 0;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
div.counter::after {
  font: 800 300px system-ui;
  content: counter(count);
  animation: counter 5s linear;
  counter-reset: count 0;
  color: #ffffff85;
}
div#help-center {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 9;
    display: flex;
    align-items: center;
    justify-content: center;
}
div#help-center > div {
    background: #ffeb3b;  
    display: flex;
    flex-direction: column;
    align-items: left;
    justify-content: center;
    color: #000;
    padding: 25px;
}
div#help-center div span {
    text-transform: uppercase;
    font-weight: 700; 
    margin-bottom: 5px;   
}

@keyframes counter {
  0% {
    counter-increment: count 5;
  }
  25% {
    counter-increment: count 4;
  }
  50% {
    counter-increment: count 3;
  }  
  75% {
    counter-increment: count 2;
  }
  100% {
    counter-increment: count 1;
  }
}

#btnAudioIcon.stop {
    background: #42ba96;
}
.role-student:not(.page-overall) .sidebar-toggler {
    display: none;
}
.navbar .menu-top-student .nav-link {
    color: #fff;
}
.navbar .menu-top-student .nav-link.active i {
    color: #467fd0;
}
.navbar .menu-top-student .nav-link.finish i {
    color: #42ba96;
}
.navbar .menu-top-student .nav-link.active:hover {
    background: #467fd050;
}
.navbar .menu-top-student .nav-link.finish:hover {   
    background: #42ba9650;
}
.navbar .menu-top-student {
    list-style: none;
    margin: 0 50px 0 0;
    display: flex;
}
.navbar .menu-top-student .nav-link i.la {
    position: relative;
    top: 1px;    
}
.main .container-fluid {
    padding-top: 20px;
}

/* overall */
.overall .title {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 20px;
}
.overall .title a { 
    float: right;
    letter-spacing: 0;
    text-transform: none;
    font-size: 1rem;
    font-weight: normal;
    line-height: 30px;
    text-decoration: underline;
}
.overall .simulation-item {
    width: 100%;
    display: flex;
    flex-direction: row;
}
.overall .simulation-item .item-header {    
    max-width: 200px;
    width: 200px;
}
.overall .simulation-item .item-body {
    padding: 10px 20px;
    width: calc(100% - 200px);
}
.overall .simulation-item .description {
    overflow: visible;
    white-space: unset;
    text-overflow: unset;
    position: relative;
}
.overall .simulation-item .description.collapsed {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-right: 75px;
}
.overall .simulation-item .more-link {
    top: 0;
    position: absolute;
    right: 0;
    background: #fff !important;
    min-width: 75px;
}
.overall .simulation-item .item-body .status {
    margin-left: 0;
    margin-right: 0;
    width: auto;
    position: absolute;
    bottom: 5px;
    right: 0;
}
.overall .simulation-item .item-edit {
    display: none !important;
}
.overall.detail .simulation-item .item-body > div.item-details {
    min-height: 160px;
}
.overall.detail .simulation-item .item-body .status {
    display: none;
}
.overall .simulation-item .item-body .status {
    background: none;
}
.page-item.active .page-link {
    background-color: #0075fd;
    border-color: #0075fd;
}
.page-link {
    color: #0075fd;
}
.simulation-item .current-case {
    display: flex;
    justify-content: flex-start;
    flex-direction: row;
    padding-top: 10px;
    border-top: 1px dotted #80808029;
}
.simulation-item .current-case .desktop-icon {
    font-size: 30px;
    width: 45px;
    text-align: left;
    display: flex;
    justify-content: center;
    flex-direction: column;
}
.overall .item-extra-details {
    display: flex;
    justify-content: flex-start;
    flex-direction: column;
}
.overall .item-extra-details .details-row {
    display: flex;
}
.overall .item-extra-details .details-row > div {
    margin-right: 30px !important;
}
#badge-fields > div {
    margin-top: 1rem;
    padding: 10px 0;
}
#badge-fields > div:nth-child(odd) {
    background: #f7f7f7;
}
#badge-fields .form-group {
    margin-bottom: .2rem;
}
#badge-fields .form-group .badge-name {
    border-bottom: 1px solid #dedede;
    display: block;
    padding-bottom: 4px;
}
.user-profile, .welcome-consultation {
    background-size: cover !important;
    background-position: center bottom !important;
    background: url('/images/profile.jpg');   
    background-repeat: no-repeat !important;
    margin-top: calc(-0.5em - 20px);
    height: calc(100% + (0.5em + 20px));
    margin-left: -30px;
    margin-right: -30px;
}
.user-badges {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 2vh 3vw;
}
.user-badges > div {
    width: auto;
    max-width: 100%;
    display: flex;
    justify-content: center;
    background: #00000085;
}
.user-badges img {
    margin: 0 15px 15px 15px;
}
.user-badges .title {
    color: #fff;
    padding: 0 50px;
    font-size: 25px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
}
.user-badges .badge-item {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 10px 0;
}
.user-badges .badge-item span {
    color: #fff;
    font-size: .9rem;
}
.consultation .box {
    color: #fff;
    padding: 0 50px;
    font-size: 25px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
}
.not-results i.la-exclamation-triangle {
    font-size: 1.5rem;
    margin-right: 8px;
}
.not-results {
    font-size: .9rem;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: .9;
    flex-wrap: wrap;
    column-count: 2;
}
.table.table-striped td strong {
    white-space: pre;
}
body.login {
    background-size: cover !important;
    background-position: bottom center !important;
    background: url('/images/profile.jpg');   
    background-repeat: no-repeat;
    justify-content: center;
}
/*body.login:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background: #ffffffb1;
    z-index: 1
}*/
body.login .container, body.login .app-footer {
    z-index: 2;
}
.top-card-info-bottom {
    position: relative;
    display: block;
    text-transform: none;
    font-weight: normal;
}
.progress-cards .card-body div {
    width: 100%;
}
.progress-cards .card-body div .text-uppercase {
    position: relative;
}
.progress-cards .card-body .text-value-sm {
    line-height: 1.1rem;
}
.menu-circle-badge {
    position: relative;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    text-align: center;
    font-size: .8rem;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 8px;
}

.login .footer-logos .bg-white {
    min-height: 72px;
    max-height: 72px;
}
body:not(.login) .app-footer {
    flex-direction: column;
    align-items: center;
    background: #e8ecf3;
}
body:not(.login) .footer-copy {
    color: #869ab8 !important;
}
body:not(.login) .app-footer .footer-logos {
    margin-bottom: 0 !important;
}
.footer-logos img {
    max-width: 120px;
}
.sticky-footer {
    height: auto !important;
}

@media screen and (max-width: 1280px) {
    .simulation-description {
        width: 100%;
        height: 100%;
        max-height: 100%;
        border-radius: 0;
        background: #00000059;
    }
    #continueSection > h1, .case-finish-front h1 {
        font-size: 1.5rem;
    }
    .case-finish-front > p {
        font-size: 1.0rem;
        line-height: 1.1rem;
    }
    .case-finish-front .la-thumbs-up,
    .case-audio-front div.micro > i {
        font-size: 30px;       
        line-height: 65px;      
        width: 65px;
        height: 65px;
        margin-bottom: 10px;
        padding: 0;
    }
}
@media screen and (max-width: 920px) {
    .case-video-toggle-top .case-action, .case-audio-actions .case-action,
    .speed-dial__button--root {
        width: 32px !important;
        height: 32px !important;
    }
    .case-video-toggle-top .case-action i, .case-audio-actions .case-action i {
        line-height: 32px;
    }
    .case-header button i, .case-header a i {
        font-size: 18px;
    }
    .case-header {
        right: 10px;
    }   
    .simulation-progress-bar {
        display: none !important;
    }
    .case-bottombar {
        max-height: 30%;
        overflow-y: auto;
    }
    .case-help > .col1, .col3.stepsbar {
        display: none !important;
    }    
    .case-help > .col2 { 
        width: 100%;
        max-width: 100%;
        padding: 10px;
    }
    #helpBubble img {
        max-width: 32px;
    }
    .case-audio-front, .case-finish-front, .simulation-front {
        padding: 20px 40px;
        max-height: 100%;
        overflow-y: auto;
        justify-content: flex-start;
    }
    #continueSection > h1, .case-finish-front h1 {
        font-size: 1rem;
    }
    .case-finish-front .bar .bar-2col {
        width: 100%;
        margin: 0;
    }
    .case-finish-front .la-thumbs-up,
    .case-audio-front div.micro > i {
        font-size: 25px;       
        line-height: 50px;      
        width: 50px;
        height: 50px;
        margin-bottom: 10px;
        padding: 0;
        overflow: visible;
    }
    .case-help-icon {
        font-size: 20px;
        padding: 0 10px;
        width: 50px;      
        height: 25px;
    }
    .btn {
        display: block;
        margin: 2px;
        width: 100%;
        font-size: .9rem;
        line-height: .9rem;
    }
    .case-finish-front .bar .progress {
        max-height: 25px;
    }
    .speed-dial__button--small {
        width: 32px !important;
        height: 32px !important;
    }
    .speed-dial [data-direction=left] {
        right: 32px !important;
        height: 32px !important;
    }
    .speed-dial:hover .speed-dial__item {
        height: 32px;
    }
    .dashboard-simulations {
        display: block;
    }    
    .simulation-item {
        width: 100%;
        margin-right: 0;
        display: block;
    }
    .dashboard-ranking .ranking-data .name,
    .dashboard-ranking .ranking-item,
    .dashboard-badges .badge-data .name,
    .dashboard-badges .badge-item {
        line-height: .9rem;
    }
    .logo + .card {
        margin-left: -15px;
        margin-right: -15px;
        border-left: none;
        border-right: none;
        border-radius: 0;
    }
    .logo > img {
        max-width: 40%;
    }
    .app.align-items-center .logo {
         margin-bottom: 1.5rem !important;
    }
    .app.align-items-center .app-footer {
        height: auto !important;
        text-align: center;
    }
    .app.align-items-center .app-footer img {
        margin-bottom: 0;
    }
    .app.align-items-center .footer-logos {
        margin-bottom: 0 !important;
    }
}



