﻿
/* Please see documentation at https://docs.microsoft.com/aspnet/core/client-side/bundling-and-minification\ 
for details on configuring this project to bundle and minify static web assets. */
body, html {
  height: 100%;
  font-family: "Josefin Sans";
  font-size: 16px;
  font-weight: 300;
  letter-spacing: 1px;
  font-style: normal;
  overscroll-behavior-x: none !important;
  overscroll-behavior-y: none !important;
  overflow-x: hidden !important;
  overflow-y: hidden !important;
}

/* Wrapping element */
/* Set some basic padding to keep content from hitting the edges */
.body-content {
  padding-left: 15px;
  padding-right: 15px;
}

/* Carousel */
.carousel-caption p {
  font-size: 20px;
  line-height: 1.4;
}

/* Make .svg files in the carousel display properly in older browsers */
.carousel-inner .item img[src$=".svg"] {
  width: 100%;
}

/* QR code generator */
#qrCode {
  margin: 15px;
}

/* Hide/rearrange for smaller screens */
@media screen and (max-width: 767px) {
  /* Hide captions */
  .carousel-caption {
    display: none;
  }
}

.svg-wrapper-overlay svg {
  display: block;
  position: relative;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.svg-wrapper svg {
  display: block;
  position: relative;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.hr {
  width: 100%;
  height: 1px;
  display: block;
  margin-top: 20px;
  margin-bottom: 20px;
  padding-top: 5px;
  border-bottom: 1px solid #DDDDDD;
}

.hr-small {
  width: 100%;
  height: 1px;
  display: block;
  padding-top: 2px;
  border-bottom: 1px solid #DDDDDD;
}

body {
  color: #747474;
}


.svg-wrapper-overlay {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 150px;
}

.form-control {
  margin-bottom: 10px;
}

.connection-panel {
  cursor: pointer;
}


.dob-year {
  border-bottom-left-radius: 0px;
  border-top-left-radius: 0px;
  margin: 0px;
  text-align: center
}

.dob-month {
  border-bottom-right-radius: 0px;
  border-top-right-radius: 0px;
  margin: 0px;
  text-align: center
}

.dob-day {
  border-radius: 0px;
  margin: 0px;
  text-align: center
}

.no-spacing {
  margin-left: 0px;
  margin-right: 0px;
  padding-left: 0px;
  padding-right: 0px;
}


.no-spacing-right {
  margin-right: 0px;
  padding-right: 0px;
}


.no-spacing-left {
  margin-left: 0px;
  padding-left: 0px;
}

.picture {
  width: 100%;
  border-radius: 5px;
  image-orientation: from-image;
}

.picture-frame, .picture-frame-flat {
  height: 100%;
  max-width: 100%;
  border: solid 1px #888;
  border-radius: 8px;
  text-align: center;
  align-content: center;
  vertical-align: central;
  align-items: center;
  padding: 5px;
  margin: 10px;
  display: inline-block;
}

.border-light {
  border: 1px solid #DDDDDD;
  border-radius: 5px;
}

.picture-frame {
  box-shadow: #808080 2px 2px 15px 0px;
}

.picture-border {
  max-width: 100%;
  border: solid 1px #808080;
  border-radius: 5px;
  image-orientation: from-image;
}

.box-shadow-inset {
  padding: 15px;
  box-shadow: inset #808080 0px 0px 5px 0px;
}

.box-shadow {
  padding: 15px !important;
  box-shadow: #808080 0px 0px 5px 0px;
}

  .box-shadow.border-light {
    padding: 15px !important;
    box-shadow: #808080 1px 1px 3px 0px;
  }

.box-shadow-no-padding {
  box-shadow: #808080 0px 0px 5px 0px;
}

.summary-flex {
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
}

.summary-box {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid #ddd;
  border-radius: 8px;
  vertical-align: central;
  padding: 15px;
  /*margin-bottom: 15px;  
  margin-top: 15px;*/
  box-shadow: #808080 2px 2px 6px 0px;
  flex: 2 0 40%;
  max-width: 49.5%;
}

.insurance-box {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid #ddd;
  border-radius: 8px;
  vertical-align: central;
  padding: 15px;
  /*margin-bottom: 15px;  
  margin-top: 15px;*/
  box-shadow: #808080 2px 2px 6px 0px;
  flex: 2 0 40%;
}

@media screen and (max-width: 767px) {
  .summary-box {
    flex: 1 0 100%;
    max-width: 100%;
  }
}

.summary-table > tbody > tr > td {
  width: 50%;
}

.summary-table > tbody > tr > td {
  vertical-align: middle;
}

/*.group-1, .group-2, .group-3, .group-4 {
  padding: 1px;
}

@media screen and (max-width: 991px) {
  .group-1, .group-2, .group-3, .group-4 {
    height: auto !important;
  }
}*/


.summary-edit-btn {
  margin-top: 20px
}

.input-container {
}

input[type='file']:not(.admin-file-upload) {
  display: none;
}

.browse-btn:hover,
.browse-btn:focus,
.browse-btn:focus-within {
  background: #80808055
}

.browse-btn {
  margin-bottom: 10px;
  background: #808080;
  color: #fff;
  min-height: 35px;
  padding: 10px;
  border: none;
  border-radius: 5px;
}

.refresh-btn {
  margin: 10px;
  min-height: 35px;
  padding: 10px;
}

.birth-date-wrapper {
  display: inline-block;
  width: 100%
}

@media screen and (max-width: 992px) {
  .birth-date-wrapper {
    display: inline-block;
    width: 100%
  }
}

.clickable {
  cursor: pointer;
}

  .clickable:hover {
    background: #EEEEEE
  }

.checkbox-lg {
  display: inline-block !important;
  height: 34px !important;
  width: 34px !important;
  margin-top: 0px !important;
  margin-bottom: 10px !important;
}

.radiobutton-lg {
  display: inline-block !important;
  height: 34px !important;
  width: 34px !important;
  margin-top: 0px !important;
  margin-bottom: 10px !important;
}

.checkbox-container-sm {
  height: 22.5px;
  padding: 0px;
  position: relative
}

.checkbox-in-container {
  position: absolute;
  top: 50%;
  height: 10em;
  margin-top: -5em;
}

.checkbox-sm {
  display: inline-block !important;
  height: 22.5px !important;
  width: 22.5px !important;
  margin: 0px !important;
}

#overlay {
  position: fixed; /* Sit on top of the page content */
  display: none; /* Hidden by default */
  width: 100%; /* Full width (cover the whole page) */
  height: 100%; /* Full height (cover the whole page) */
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0,0,0,0.5); /* Black background with opacity */
  z-index: 2; /* Specify a stack order in case you're using a different order for other elements */
  cursor: pointer; /* Add a pointer on hover */
}


.glyphicon.fast-right-spinner {
  -webkit-animation: glyphicon-spin-r 1s infinite linear;
  animation: glyphicon-spin-r 1s infinite linear;
}

.glyphicon.normal-right-spinner {
  -webkit-animation: glyphicon-spin-r 2s infinite linear;
  animation: glyphicon-spin-r 2s infinite linear;
}

.glyphicon.slow-right-spinner {
  -webkit-animation: glyphicon-spin-r 3s infinite linear;
  animation: glyphicon-spin-r 3s infinite linear;
}

.glyphicon.fast-left-spinner {
  -webkit-animation: glyphicon-spin-l 1s infinite linear;
  animation: glyphicon-spin-l 1s infinite linear;
}

.glyphicon.normal-left-spinner {
  -webkit-animation: glyphicon-spin-l 2s infinite linear;
  animation: glyphicon-spin-l 2s infinite linear;
}

.glyphicon.slow-left-spinner {
  -webkit-animation: glyphicon-spin-l 3s infinite linear;
  animation: glyphicon-spin-l 3s infinite linear;
}

@-webkit-keyframes glyphicon-spin-r {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}

@keyframes glyphicon-spin-r {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}

@-webkit-keyframes glyphicon-spin-l {
  0% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }

  100% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}

@keyframes glyphicon-spin-l {
  0% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }

  100% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}

.signature_pad {
  width: 700px;
  height: 400px;
  margin: 0 auto;
}

.signature_pad_body canvas {
  width: 100%;
  height: 100%;
  border: dotted #444;
  background: #CCCCCC;
}

.validation-error-row {
  margin-top: -10px !important;
}

.radio-td {
  cursor: pointer;
}

  .radio-td:hover {
    background: #EEEEEE
    /*box-shadow: inset 0px 0px 3px 0px grey;*/
  }

  .radio-td:active {
    background: #DDDDDD
    /*box-shadow: inset 0px 0px 5px 0px grey;*/
  }



.radio-tile-hidden {
  padding: 1rem;
}

.radio-tile {
  cursor: pointer;
  padding: 1rem;
}

input.day-input {
  display: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
}

input.month-input {
  display: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
}

.radio-tile:has(input:checked) {
  cursor: pointer;
  padding: 1rem;
  /*background: #EEEEEE;*/
  padding: 15px;
  box-shadow: #808080 0px 0px 5px 0px;
}

.radio-tile:hover {
  background: #EEEEEE
  /*box-shadow: inset 0px 0px 3px 0px grey;*/
}

.radio-tile:active {
  background: #DDDDDD
  /*box-shadow: inset 0px 0px 5px 0px grey;*/
}


.checkbox-td {
  cursor: pointer;
}

  .checkbox-td:hover {
    background: #EEEEEE
    /*box-shadow: inset 0px 0px 3px 0px grey;*/
  }

  .checkbox-td:active {
    background: #DDDDDD
    /*box-shadow: inset 0px 0px 5px 0px grey;*/
  }

.unselectable {
  cursor: default;
  background: #DDD;
  -webkit-user-select: none; /* Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+/Edge */
  user-select: none; /* Standard */
}

.selectable:not(.unselectable) {
  cursor: pointer;
  -webkit-user-select: none; /* Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+/Edge */
  user-select: none; /* Standard */
}

  .selectable:not(.unselectable):hover {
    background: #EEEEEE
  }

  .selectable:not(.unselectable):active {
    background: #DDDDDD
  }

.selectable-item {
  cursor: pointer;
}

  .selectable-item:hover,
  .selectable-item:focus,
  .selectable-item.active {
    background: #EEEEEE
  }

.no-select {
  -webkit-user-select: none; /* Chrome/Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+ */
  /* Rules below not implemented in browsers yet */
  -o-user-select: none;
  user-select: none;
}

.collapsable {
  -webkit-user-select: none; /* Chrome/Safari */
  -moz-user-select: none; /* Firefox */
  -ms-user-select: none; /* IE10+ */
  /* Rules below not implemented in browsers yet */
  -o-user-select: none;
  user-select: none;
  cursor: pointer;
}

.log-div {
  margin: 20px;
  box-shadow: black 3px 3px 3px 3px;
}

.strike-through {
  text-decoration: line-through;
}

.center-container {
  position: relative;
}

.vertical-center {
  margin: 0;
  position: absolute;
  top: 50%;
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

table.middle-align-cells tbody tr td {
  vertical-align: middle !important;
}


@media (max-width: 767px) {
  .col-mt-20 {
    margin-top: 20px;
  }

  .col-mt-30 {
    margin-top: 30px;
  }

  .col-mt-40 {
    margin-top: 40px;
  }

  .col-mt-50 {
    margin-top: 50px;
  }
}

.clinic-logo-main {
  max-height: 60px;
  height: auto;
  position: relative;
  left: 0px;
  top: -40px;
  width: auto
}

.clinic-logo-layout {
  display: none;
}

.svg-wrapper {
  display: block;
  position: relative;
  width: 100%;
  height: 150px;
}

#title {
  text-align: center;
}

@media (max-width: 767px) {

  .page-title {
    margin: 0px;
    align-self: center;
  }

  #title {
    margin-top: 20px;
    display: flex;
    align-items: flex-start;
    justify-content: space-around;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 2rem;
  }

  .clinic-logo-main {
    display: none;
  }

  .clinic-logo-layout {
    display: inline-block;
    max-height: 60px;
    height: auto;
    width: auto;
  }

  .svg-wrapper {
    display: block;
    position: relative;
    width: 100%;
    height: 30px;
  }
}

.visit-bundle-button-row {
  padding-bottom: 10px;
  /*box-shadow: 0px -15px 10px -15px gray;*/
  margin-top: 10px;
}

.sticky-top {
  position: sticky;
  top: 0px;
  padding-bottom: 10px;
  background-color: white;
}

.sticky-bottom {
  position: sticky;
  bottom: 0px;
  padding-top: 10px;
  background-color: white;
}



.row.display-flex {
  display: flex;
  flex-wrap: wrap;
}

  .row.display-flex > [class*='col-'] {
    display: flex;
    flex-direction: column;
  }

.h-100 {
  height: 100%;
}

.document {
  padding-bottom: 2rem;
}

.w-100 {
  width: 100%;
}

.display {
  padding: 0px;
  background: transparent;
  border-radius: 1rem;
  border: none;
}

.display-design {
  padding: 0px;
  border: 1px solid #808080;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding-right: 20px;
  border-radius: 1rem;
  padding-top: 0px;
  padding-left: 0px;
  padding-bottom: 0px;
  background: white;
  gap: 1rem;
}

.display-start-tag {
  padding: .75rem 1.5rem;
  color: white;
  padding-left: 1.5rem;
  border-radius: 1rem 0rem 0rem 1rem;
  display: flex;
  align-items: center
}


.display-start-tag-small {
  padding: 0rem;
  color: white;
  padding-left: 0rem;
  border-radius: 1rem 0rem 0rem 1rem;
  display: flex;
  align-items: center
}

.display-end-tag {
  padding-right: 1.5rem;
  padding-left: 1.5rem;
  padding-top: .75rem;
  padding-bottom: .75rem;
  color: white;
  border-radius: 1rem 0rem 0rem 1rem;
  display: flex;
  align-items: center
}

.return-button {
  padding: 0px;
  background: transparent;
  border-radius: 1rem;
  border: none;
  display: flex;
  justify-content: stretch
}

.return-button-design {
  padding: 15px;
  box-shadow: #808080 1px 1px 3px 0px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding-right: 0px;
  border-radius: 1rem;
  padding-top: 0px;
  padding-left: 20px;
  padding-bottom: 0px;
  background: white;
  gap: 1rem;
}

  .return-button-design:hover,
  return-button-design:active,
  return-button-design:focus {
    box-shadow: #808080 0px 0px 5px 0px;
  }

.continue-button {
  padding: 0px;
  background: transparent;
  border-radius: 1rem;
  border: none;
  display: flex;
  justify-content: stretch
}

.continue-button-design {
  padding: 15px;
  box-shadow: #808080 1px 1px 3px 0px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding-right: 20px;
  border-radius: 1rem;
  padding-top: 0px;
  padding-left: 0px;
  padding-bottom: 0px;
  background: white;
  gap: 1rem;
}

  .continue-button-design:hover,
  continue-button-design:active,
  continue-button-design:focus {
    box-shadow: #808080 0px 0px 5px 0px;
  }

.continue-button-start-tag {
  padding: 1rem 1.5rem;
  color: white;
  border-radius: 1rem 0rem 0rem 1rem;
  display: flex;
  align-items: center
}

.continue-button-start-tag-small {
  padding: .25rem .5rem;
  color: white;
  border-radius: 1rem 0rem 0rem 1rem;
  display: flex;
  align-items: center
}

.return-button-start-tag {
  padding: 1rem 1.5rem;
  color: white;
  border-radius: 0rem .95rem .95rem 0rem;
  display: flex;
  align-items: center;
}

.text-wrap {
  overflow-wrap: break-word;
  text-wrap: wrap;
}



/* blue bar */
.shiny-box {
  background: white;
  z-index: 0;
  position: relative;
  overflow: hidden;
}

/* text */
.shiny-text {
  color: #fff;
  left: 50%;
  transform: translate(-50%,-50%);
  position: absolute;
  display: inline-block;
  font-size: 30px;
  font-family: 'open sans',sans-serif;
  letter-spacing: -1px;
  font-weight: bold;
}

/*a {
  color: #bbb;
  font-size: 11px;
  bottom: 20px;
  font-weight: 400;
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: 1px;
}*/

/* Shine */
.shiny-box:after {
  content: '';
  top: 0;
  transform: translateX(100%);
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 1;
  animation: slide 1s;
  /* 
  CSS Gradient - complete browser support from http://www.colorzilla.com/gradient-editor/ 
  */
  background: -moz-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,0.8) 50%, rgba(128,186,232,0) 99%, rgba(125,185,232,0) 100%); /* FF3.6+ */
  background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(255,255,255,0)), color-stop(50%,rgba(255,255,255,0.8)), color-stop(99%,rgba(128,186,232,0)), color-stop(100%,rgba(125,185,232,0))); /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 50%,rgba(128,186,232,0) 99%,rgba(125,185,232,0) 100%); /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 50%,rgba(128,186,232,0) 99%,rgba(125,185,232,0) 100%); /* Opera 11.10+ */
  background: -ms-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 50%,rgba(128,186,232,0) 99%,rgba(125,185,232,0) 100%); /* IE10+ */
  background: linear-gradient(to right, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 50%,rgba(128,186,232,0) 99%,rgba(125,185,232,0) 100%); /* W3C */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#007db9e8',GradientType=1 ); /* IE6-9 */
}

/* animation */

@keyframes slide {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(100%);
  }
}


/* The container */
.radio-select-container {
  display: block;
  position: relative;
  padding-left: 35px;
  margin-bottom: 12px;
  cursor: pointer;
  font-size: 22px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

  /* Hide the browser's default checkbox */
  .radio-select-container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
  }

/* Create a custom checkbox */
.checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: #eee;
}

/* On mouse-over, add a grey background color */
.radio-select-container:hover input ~ .checkmark {
  background-color: #ccc;
}

/* When the checkbox is checked, add a blue background */
.radio-select-container input:checked ~ .checkmark {
  background-color: #2196F3;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the checkmark when checked */
.radio-select-container input:checked ~ .checkmark:after {
  display: block;
}

/* Style the checkmark/indicator */
.container .checkmark:after {
  left: 9px;
  top: 5px;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}


h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: inherit;
  font-weight: 500;
  line-height: 1.1;
  color: inherit;
}

  h1 small,
  h2 small,
  h3 small,
  h4 small,
  h5 small,
  h6 small,
  .h1 small,
  .h2 small,
  .h3 small,
  .h4 small,
  .h5 small,
  .h6 small,
  h1 .small,
  h2 .small,
  h3 .small,
  h4 .small,
  h5 .small,
  h6 .small,
  .h1 .small,
  .h2 .small,
  .h3 .small,
  .h4 .small,
  .h5 .small,
  .h6 .small {
    font-weight: 400;
    line-height: 1;
    color: inherit;
  }

h1,
.h1,
h2,
.h2,
h3,
.h3 {
  padding-top: 20px;
  padding-bottom: 10px;
}

  h1 small,
  .h1 small,
  h2 small,
  .h2 small,
  h3 small,
  .h3 small,
  h1 .small,
  .h1 .small,
  h2 .small,
  .h2 .small,
  h3 .small,
  .h3 .small {
    font-size: 65%;
  }

h4,
.h4,
h5,
.h5,
h6,
.h6 {
  padding-top: 10px;
  padding-bottom: 10px;
}

  h4 small,
  .h4 small,
  h5 small,
  .h5 small,
  h6 small,
  .h6 small,
  h4 .small,
  .h4 .small,
  h5 .small,
  .h5 .small,
  h6 .small,
  .h6 .small {
    font-size: 75%;
  }

h1,
.h1 {
  font-size: 36px;
}

h2,
.h2 {
  font-size: 30px;
}

h3,
.h3 {
  font-size: 24px;
}

h4,
.h4 {
  font-size: 18px;
}

h5,
.h5 {
  font-size: 14px;
}

h6,
.h6 {
  font-size: 12px;
}

.blur {
  filter: blur(1.5rem)
}

.image-display {
  max-width: 550px;
  width: 100%;
  height: auto;
}

.video-container {
  position: relative;
  height: 100%;
  width: 100%;
}

.video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  max-height: calc(100dvh - 190px)
}

#camera-buttons {
  display: flex;
  flex-direction: row;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}

.modal-title {
  display: flex;
  flex-direction: row;
  justify-content: center;
  max-width: 100vw;
}

.camera-modal {
  width: 100%;
  display: flex;
  flex-direction: column;
}

  .camera-modal.Landscape {
    width: 100vw;
    flex-direction: row;
  }

    .camera-modal.Landscape > .modal-title {
      display: none;
    }

    .camera-modal.Landscape > #camera-buttons {
      flex-direction: column;
      width: auto;
    }

    .camera-modal.Landscape > .video-container {
      position: relative;
      max-width: calc(100vw - 82px);
      height: 100%;
    }

      .camera-modal.Landscape > .video-container > .video {
        height: 100%;
        max-width: calc(100vw - 82px);
        max-height: 100dvh
      }



/*.video-container.Landscape {
  position: relative;
  max-width: calc(100vw - 82px);
  height: 100%;
}


.video.Landscape {
  height: 100%;
  max-width: calc(100vw - 82px);
  max-height: 100vh
}*/

.mask {
  position: absolute;
  top: 0;
  left: 0;
  height: 100dvh;
  width: 100vw;
  z-index: 100;
  backdropFilter: blur(2px);
}


/*** Full screen styles ***/

:-webkit-full-screen {
  /* properties */
}

:-moz-full-screen {
  /* properties */
}

:-ms-fullscreen {
  /* properties */
}

:full-screen { /*pre-spec */
  /* properties */
}

:fullscreen { /* spec */
  /* properties */
}

/* deeper elements */
/*:-webkit-full-screen video {
  width: 100%;
  height: 100%;
}*/

/* styling the backdrop*/
::backdrop {
  /* properties */
}

::-ms-backdrop {
  /* properties */
}

/*body {
  display: grid;
  margin: 0;
  height: 100vh;
  grid-template:
    "messages" 1fr
    "input" auto
    "keyboard" env(keyboard-inset-height, 0px);
}*/
/*
.virtualKeyboardBody {
  height:100vh;
  display: flex;
  overflow:auto;
  flex-direction:column;
  flex-basis: 1, grow;
  display: grid;
  margin: 0;
  height: 100vh;
  grid-template:
    "messages" 1fr
    "input" auto
    "keyboard" env(keyboard-inset-height, 0px);
}
*/

.environmentKeyboardBody {
  display: grid;
  margin: 0;
  height: 100dvh;
  overflow: auto;
  grid-template:
    "messages" 1fr
    "input" auto
    "keyboard" env(keyboard-inset-height, 0px);
}

.dialogKeyboardBody {
  display: grid;
  margin: 0;
  height: 100%;
  overflow: auto;
  grid-template:
    "messages" 1fr
    "input" auto
    "keyboard" env(keyboard-inset-height, 0px);
}

.full-screen-modal {
  margin: 0px !important;
  overflow: auto;
  width: 100vw !important;
}

.full-screen-modal-content {
  width: 100vw !important;
}

/*.keyboard {
  position: fixed;
  top: 100vh;
  transform: translateY(-100%)
}*/

.keyboard-tray {
  background-color: #ececec;
}

.key {
  height: 3rem;
  width: 100%;
}

  .key.md {
    width: 110%;
  }


  .key.lg {
    width: 150%;
  }

  .key.xlg {
    width: 175%;
  }

  .key.space {
    width: 1000%
  }


.page-wrapper {
  box-sizing: border-box;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.page-header, .page-footer {
  flex-grow: 0;
  flex-shrink: 0;
}

.page-body {
  flex-grow: 1;
}

.hg-button {
  height: 55px !important;
}

.simple-keyboard {
  max-width: 1320px !important;
}


.hg-button-enter > span {
  font-weight: bold;
  font-size: 30px;
  padding-bottom: -10px;
  transform: translateY(5px);
}

.hidden {
  opacity: 0;
  pointer-events: none;
}

.sticky-footer {
  position: sticky;
  bottom: 0;
  left: 0;
  background: #DDDDDD95;
  width: 100%;
  padding: 10px;
  text-align: right;
}
