.ember-animated-hidden {
    visibility: hidden !important;
}

.ember-animated-none {
    display: none !important;
}

.ember-animated-top-collapse {
    margin-top: 0px !important;
}

.animated-container {
    position: relative;
}

.animated-container:before, .animated-container:after {
    content: ' ';
    display: table;
}

.animated-orphans {
    position: relative;
}

/*
  The code below has been extracted from the following projects:

  - https://github.com/murtaugh/HTML5-Reset
  - http://meyerweb.com
  - http://html5doctor.com
  - http://html5boilerplate.com

  … and then cleaned up a lot.
*/

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
code,
em,
img,
small,
strong,
sub,
sup,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
footer,
header,
nav,
section,
time,
audio,
video {
  padding: 0;
  border: 0;
  margin: 0;
  background: transparent;
  font-size: 100%;
  font-weight: inherit;
  vertical-align: baseline;
}

article,
aside,
figure,
footer,
header,
nav,
section {
  display: block;
}

html {
  box-sizing: border-box;
  overflow-y: scroll;
}

html,
body {
  background-color: #fff;
  color: #000;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

img,
object {
  max-width: 100%;
}

ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

th {
  font-weight: bold;
  vertical-align: bottom;
}

td {
  font-weight: normal;
  vertical-align: top;
}

input,
select {
  vertical-align: middle;
}

input[type='radio'] {
  vertical-align: text-bottom;
}

input[type='checkbox'] {
  vertical-align: bottom;
}

strong {
  font-weight: bold;
}

label,
input[type='file'] {
  cursor: pointer;
}

input,
select,
textarea {
  border: 0;
  border-radius: 0;
  margin: 0;
}

button,
input[type='button'],
input[type='submit'] {
  padding: 0;
  border: 0;
  border-radius: 0;
  margin: 0;
  background: transparent;
  appearance: none;
  cursor: pointer;
}

button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

.clock-bulletin {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  z-index: 1;
}
.clock-bulletin .analog-clock-container {
  position: relative;
  width: 100%;
  height: 100%;
}
.clock-bulletin .analog-clock-container .clock-face-container {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.clock-bulletin .analog-clock-container .clock-face-container .clock-face {
  position: relative;
}
.clock-bulletin .analog-clock-container .clock-hands-container {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}
.clock-bulletin .analog-clock-container .clock-hands-container .clock-hands {
  width: 80%;
  height: 80%;
}
.clock-bulletin .text-container {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
}
.clock-bulletin .text {
  padding: 2%;
  display: inline-block;
  line-height: 1em;
}
.no-scrollbars {
  overflow: hidden;
}

* {
  box-sizing: border-box;
}

html {
  font-size: 1vw;
  background-color: transparent;
}

body {
  padding: 0;
  margin: 0;
  color: #555c6c;
  font-size: 2em;
  background-color: transparent;
}

.verbose-logging {
  position: absolute;
  text-align: center;
  width: 100%;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.3);
  color: #FFF;
  padding: 0.2em 0.5em;
  font-size: 0.6rem;
  z-index: 2;
}

.channel-display {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: black;
}
.channel-display > * {
  overflow: hidden !important;
}

#video-wormhole {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
}

.image-bulletin {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

.interactive-bulletin {
  height: 100%;
}

.frame {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: white;
  transform-origin: 0 0;
}

.power-bi-bulletin {
  height: 100%;
}

.frame {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  transform-origin: 0 0;
}

.video-play-button {
  position: absolute;
  z-index: 9999;
  background-color: rgba(55, 55, 55, 0.7);
  display: flex;
  align-content: center;
}
.video-play-button button {
  flex: 1;
  background: transparent;
  border: none;
}
.video-play-button img {
  margin: auto;
  display: block;
  opacity: 0.8;
  width: 30%;
}

.video-player {
  width: 100%;
  height: 100%;
  background-color: black;
  position: absolute;
  object-fit: fill;
  top: 0;
  left: 0;
  z-index: 3;
}
.video-player::-webkit-media-controls-overlay-play-button {
  -webkit-appearance: none;
  display: none;
}
.video-player::-webkit-media-controls-start-playback-button {
  -webkit-appearance: none;
  display: none;
}

.web-bulletin {
  height: 100%;
}

.frame {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  transform-origin: 0 0;
}

.web-proxy-bulletin {
  height: 100%;
}

.frame {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  transform-origin: 0 0;
}

.frame {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 1;
  transition: opacity ease-in 400ms;
}
.frame.transparent {
  opacity: 0;
}

.zone-content {
  position: relative;
  height: 100%;
  width: 100%;
}

.zone-display {
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100.1% 100.1%;
  overflow: hidden;
}