html {
    height: 100%
}

*, html, body {
    box-sizing: border-box
}

* {
    outline: none
}

.modal {
    z-index: 12050
}

body {
    font-family: "Roboto", sans-serif;
    position: relative;
    padding-bottom: 3.5rem;
    padding-top: 64px;
    min-height: 100%
}

body p {
    margin: 0
}

body a:hover, body a:focus {
    cursor: pointer;
    text-decoration: none;
    color: #0a9
}

img.opacity {
    opacity: 0.2
}

.footer {
    position: fixed;
    bottom: 0;
    width: 100%;
    height: 3.5rem;
    background-color: #efefef;
    z-index: 1200
}

.footer .container {
    margin-top: 1rem
}

header {
    position: fixed;
    top: 0;
    left: 0;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.24), 0 0 4px 0 rgba(0, 0, 0, 0.12);
    z-index: 1200;
    width: 100%;
    max-width: 100%;
    background-color: #2B2830;
    margin: 0
}

.visible-flex {
    display: flex !important
}

.visible-block {
    display: block !important
}

.header {
    margin: 0 !important;
    display: flex;
    align-items: center
}

.header .burger {
    display: none;
    background: url(../img/icon-menu.svg);
    width: 24px;
    height: 24px
}

.logo-container {
    text-align: center
}

.menu, .user-cabinet {
    display: flex;
    align-items: center;
    padding-left: 8px
}

.menu-item, .menu-item-username {
    text-transform: uppercase;
    color: #fff;
    font-weight: 500;
    font-size: 12px;
    padding: 0 20px 0 0;
    position: relative
}

.menu-item span.beta, .menu-item-username span.beta {
    position: absolute;
    text-transform: lowercase;
    right: 0;
    top: -11px;
    background: red;
    padding: 1px 4px;
    border-radius: 8px;
    font-size: 8px
}

.user-cabinet {
    display: flex;
    justify-content: flex-end
}

.user-cabinet a {
    margin: 0 24px 0 0;
    padding: 0;
    font-size: 12px
}

.menu-item-username {
    text-transform: none;
    font-size: 14px !important
}

.hover-item-container {
    overflow: hidden;
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    width: 120px;
    height: 80px;
    border-radius: 4px;
    top: -85px;
    left: -50px;
    background-color: rgba(43, 40, 48, 0.6)
}

.hover-item-container .info {
    background-color: rgba(43, 40, 48, 0.6);
    border-radius: 4px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    z-index: 20
}

.hover-item-container .info img {
    margin: 5px;
    width: 18px;
    height: 18px
}

.hover-item-container .info p {
    margin-right: 5px;
    font-size: 10px
}

.hover-item-container .img-background {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.video-controls-container .row {
    margin-left: 0;
    margin-right: 0
}

.video-player-container {
    background-color: #2B2830;
    min-width: 100%;
    min-height: 600px;
    height: 65vh;
    font-size: 0;
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 50;
    overflow: hidden
}

.video-player-container1 {
    min-height: 300px;
    background: #2B2830;
    position: relative
}

.video-player-container1 video {
    top: 50%;
    z-index: 1;
    height: 100%
}

.video-player-container1 .currentCameraTime {
    z-index: 3;
    top: 10px;
    left: 10px;
    margin: 0;
    padding: 0
}

.video-player-container1:hover {
    box-shadow: 0 0 11px rgba(0, 170, 153, 0.99);
}

.rec {
    display: none;
    justify-content: flex-start;
    position: absolute;
    top: 18px;
    left: 24px;
    color: #fff;
    padding: 2px 5px 2px 5px;
    font-size: 8px;
    font-weight: 500;
    margin-left: 12px
}

.rec .red-circle {
    background-color: #ff2211;
    border-radius: 100%;
    height: 12px;
    width: 12px;
    margin-right: 4px
}

.currentCameraTime {
    display: none;
    justify-content: flex-start;
    position: absolute;
    top: 40px;
    left: 24px;
    color: #fff;
    padding: 2px 5px 2px 5px;
    font-size: 14px;
    font-weight: 500;
    margin-left: 12px
}

.camera-offline {
    display: none;
    font-size: 14px;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center
}

.camera-offline button {
    width: auto;
    margin: 5px 0 0 0;
    outline: none
}

.video-stream-properties {
    font-size: 10px;
    color: #fff;
    text-align: right
}

.video-player {
    max-width: 100% !important;
    max-height: 100% !important;
    height: calc(100% - 140px);
    position: absolute;
    top: calc(50% - 70px);
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1
}

.video-player-img {
    max-width: 100% !important;
    max-height: 100% !important;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1
}

.fullscreen-mode-video-player {
    height: calc(100% - 70px);
    top: calc(50% - 35px)
}

.fullscreen-mode-video-player.video-player-img {
    width: auto
}

.video-controls-container {
    width: 100%;
    height: auto;
    position: absolute;
    bottom: 0;
    background: linear-gradient(to top, #040404 0%, transparent 90%)
}

body > div.video-player-container > div.video-controls-container > div:nth-child(1) {
    position: relative
}

.in-corner-camera-preview {
    padding: 0 0 15px 0;
    display: none;
    flex-direction: column;
    justify-content: flex-end;
    position: absolute;
    bottom: 75px;
    right: 16px
}

.in-corner-camera-preview .microphone-button {
    width: 24px;
    height: 24px;
    background: url(../img/icon-mic.svg) no-repeat center
}

.in-corner-camera-preview .microphone-off-button {
    background: url(../img/icon-mic-off.svg) no-repeat center;
    filter: invert(100%)
}

.in-corner-camera-preview .preview-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: #fff;
    padding: 0 0 8px 16px
}

.in-corner-camera-preview .camera-preview-player {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    max-width: 200px
}

.green-hover-on-button {
    background-color: rgba(0, 170, 153, 0.3) !important
}

.top-controls {
    position: relative;
    padding: 0 16px 0 16px;
    display: flex;
    align-items: center;
    width: 100%;
    height: 40px;
    margin: 8px 0 12px 0
}

.top-controls select {
    width: auto;
    height: 24px;
    border-radius: 8px;
    font-size: 12px;
    background-color: rgba(41, 36, 36, 0);
    color: #fff;
    margin: 0 0 0 8px;
    padding: 0 3px 0 3px
}

.top-controls select {
    -webkit-appearance: none;
    -moz-appearance: none;
    text-indent: 1px;
    text-overflow: '';
    outline: none
}

.top-controls option {
    border: none;
    outline: none
}

.top-controls .select-period-container {
    display: none
}

.top-controls .selected-period-button {
    border-radius: 8px !important;
    border: 1px solid #fff !important
}

.top-controls .period-buttons {
    display: flex;
    justify-content: flex-start
}

.top-controls .period-buttons button {
    width: auto;
    height: 24px;
    font-size: 12px;
    background-color: rgba(41, 36, 36, 0);
    color: #fff;
    margin: 0 0 0 8px;
    padding: 0 10px 0 10px;
    border-radius: 8px;
    border: none;
    outline: none
}

.top-controls p {
    color: #fff !important;
    font-family: "Roboto", sans-serif;
    font-size: 14px;
    font-weight: 300;
    padding: 0 0 0 16px;
    margin: 0
}

.top-controls .left-controls-container {
    display: flex;
    padding: 0
}

.top-controls .middle-controls-stream-container {
    display: flex;
    justify-content: space-around;
    align-items: center
}

.top-controls .middle-controls-stream-container.margin-bottom-for-mcsc {
    margin-bottom: 12px
}

.top-controls .middle-controls-stream-container .volume-button {
    background: url(../img/volume-on.svg) center no-repeat;
    background-size: 24px;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    position: relative
}

.top-controls .middle-controls-stream-container .volume-button.volume-off-button {
    background: url(../img/volume-off.svg) center no-repeat;
    background-size: 24px
}

.top-controls .middle-controls-stream-container .volume-button .volume-bar-background {
    display: none;
    position: relative;
    height: 130px;
    width: 56px;
    top: -90px;
    left: -10px;
    border: none
}

.top-controls .middle-controls-stream-container .volume-button .volume-bar {
    display: block;
    height: 77px;
    width: 2px;
    top: 13px;
    left: 27px;
    border: none
}

.top-controls .middle-controls-stream-container .volume-button .volume-bar div {
    background: #0a9;
    z-index: 1003
}

.top-controls .middle-controls-stream-container .volume-button .volume-bar span {
    width: 12px;
    height: 12px;
    background: #0a9;
    border-radius: 100%;
    border: none;
    left: -5px;
    outline: none;
    z-index: 1002
}

.top-controls .middle-controls-stream-container .photo-camera-button {
    background: url(../img/photocamera.svg) no-repeat center;
    width: 36px;
    height: 36px;
    border-radius: 100%
}

.top-controls .middle-controls-stream-container .fullscreen-button {
    margin: 0
}

.top-controls .middle-controls-stream-container .volume-off-button {
    border-radius: 100%;
    background: url(../img/volume-off.svg) center no-repeat
}

.top-controls .middle-controls-stream-container .video-camera-button {
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    background: url(../img/videocamera.svg) center no-repeat;
    position: relative
}

.top-controls .middle-controls-stream-container .video-camera-button .white-circle {
    border-radius: 50px;
    border: 1px solid #ffffff;
    width: 40px;
    height: 40px;
    position: absolute;
    top: 0;
    left: 0
}

.top-controls .middle-controls-stream-container .video-camera-button .red-circle {
    background: red;
    position: absolute;
    top: 3px;
    left: 3px;
    width: 34px;
    height: 34px;
    border-radius: 50px;
    border: none;
    z-index: -1
}

.top-controls .middle-controls-stream-container .video-camera-button:hover {
    background-color: rgba(0, 170, 153, 0.3);
    transition: 0.5s;
    border-radius: 50px
}

.top-controls .middle-controls-stream-container .phone-button {
    width: 48px;
    height: 48px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #ffffff;
    background: url(../img/phone.svg) no-repeat center;
    border-radius: 100%
}

.top-controls .middle-controls-stream-container .phone-button:hover {
    background-color: rgba(0, 170, 153, 0.3);
    transition: 0.5s
}

.top-controls .middle-controls-stream-container .drop-phone-button {
    background: url(../img/drop-phone.svg) no-repeat center red;
    border-radius: 50px;
    border: none
}

.download-and-delete-container {
    display: none;
    flex-direction: column;
    justify-content: flex-end;
    padding-bottom: 5px;
    max-width: 30%
}

.download-and-delete-container div {
    display: flex;
    justify-content: flex-end;
    align-items: center
}

.download-and-delete-container .time-indicator {
    color: #fff;
    font-size: 1.3rem;
    width: 36px;
    overflow: visible;
    white-space: pre
}

.download-and-delete-container .video-info-status {
    color: #fff;
    font-size: 24px;
    text-align: right
}

.download-and-delete-container .delete-item {
    background: url(../img/icon-delete.svg) no-repeat center;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    margin: 0 10px
}

.download-and-delete-container .download-item {
    background: url(../img/icon-download.svg) no-repeat center;
    width: 36px;
    height: 36px;
    border-radius: 100%
}

.video-progress-indicator {
    display: none;
    height: 12px;
    width: 100%;
    position: relative
}

.grey-line {
    width: 100%;
    height: 1px;
    position: absolute;
    left: 0;
    bottom: 6px;
    background: rgba(255, 255, 255, 0.26)
}

.green-dot {
    right: 0;
    bottom: -5px;
    position: absolute;
    width: 12px;
    height: 12px;
    border-radius: 6px;
    background: #0a9
}

.green-line {
    width: 0;
    max-width: 100%;
    height: 2px;
    bottom: 5px;
    left: 0;
    position: absolute;
    background: #0a9;
    display: flex;
    justify-content: flex-end;
    overflow: visible !important
}

.middle-controls-video-player-container {
    display: none;
    justify-content: center;
    align-items: center
}

.middle-controls-video-player-container .video-volume-button {
    background: url(../img/volume-on.svg) center no-repeat;
    background-size: 24px;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    position: relative
}

.middle-controls-video-player-container .video-volume-button.video-volume-off-button {
    background: url(../img/volume-off.svg) center no-repeat;
    background-size: 24px
}

.middle-controls-video-player-container .video-volume-button .volume-bar-background {
    display: none;
    position: relative;
    height: 130px;
    width: 56px;
    top: -90px;
    left: -10px;
    border: none
}

.middle-controls-video-player-container .video-volume-button .video-volume-bar {
    display: block;
    height: 77px;
    width: 2px;
    top: 13px;
    left: 27px;
    border: none
}

.middle-controls-video-player-container .video-volume-button .video-volume-bar div {
    background: #0a9;
    z-index: 1003
}

.middle-controls-video-player-container .video-volume-button .video-volume-bar span {
    width: 12px;
    height: 12px;
    background: #0a9;
    border-radius: 100%;
    border: none;
    left: -5px;
    outline: none;
    z-index: 1002
}

.middle-controls-video-player-container .prev-video-button {
    background: url(../img/vector-prev.svg) no-repeat center;
    width: 36px;
    height: 36px;
    margin-left: 48px;
    border-radius: 100%
}

.middle-controls-video-player-container .play-stop-button {
    width: 48px;
    height: 48px;
    border: 1px solid #ffffff;
    margin: 0 32px 0 32px;
    background: url(../img/icon-play.svg) no-repeat center;
    background-size: 50% 50%;
    border-radius: 100%
}

.middle-controls-video-player-container .play-stop-button:hover {
    border-radius: 50px;
    background-color: rgba(0, 170, 153, 0.3);
    transition: 0.5s
}

.middle-controls-video-player-container .stop-background-button {
    background: url(../img/icon-pause.svg) no-repeat center;
    background-size: 60% 60%
}

.middle-controls-video-player-container .next-video-button {
    background: url(../img/vector-next.svg) no-repeat center;
    width: 36px;
    height: 36px;
    margin-right: 48px;
    border-radius: 100%
}

.fullscreen-button {
    background: url(../img/full.svg) no-repeat center;
    width: 36px;
    height: 36px;
    border-radius: 100%
}

.collapse-full-screen {
    background: url(../img/icon-collapse.svg) no-repeat center;
    background-size: 24px 24px
}

.hover-on-button, .top-controls .middle-controls-stream-container .volume-button:hover, .top-controls .middle-controls-stream-container .photo-camera-button:hover, .download-and-delete-container .delete-item:hover, .download-and-delete-container .download-item:hover, .middle-controls-video-player-container .video-volume-button:hover, .middle-controls-video-player-container .prev-video-button:hover, .middle-controls-video-player-container .next-video-button:hover, .fullscreen-button:hover, .video-info .subscription-container .share-black:hover, .video-info .subscription-container .settings-black:hover {
    background-color: rgba(0, 170, 153, 0.3);
    width: 36px;
    height: 36px;
    transition: 0.5s
}

.right-controls-container {
    display: flex;
    justify-content: flex-end;
    padding: 0
}

.live-button {
    position: absolute;
    bottom: 15px;
    right: 15px;
    padding: 0 10px 0 10px;
    border-radius: 5px;
    border: 1px solid #ffffff;
    font-size: 14px;
    color: #fff;
    z-index: 500;
    cursor: pointer;
    display: none;
    justify-content: center
}

.live-button p {
    padding: 0
}

.hard-overflow-visible {
    overflow: visible !important
}

.timeline-container {
    height: 100%;
    min-height: 70px;
    font-size: 12px
}

.timeline-container .vis-item.vis-range {
    min-width: 2px
}

.timeline-container .vis-item.vis-range .vis-item-overflow {
    overflow: visible
}

.timeline-container .vis-content {
    top: 0 !important;
    height: 100%
}

.timeline-container .vis-horizontal {
    height: 100% !important
}

.timeline-container .vis-panel.vis-center {
    height: 100% !important
}

.timeline-container .vis-itemset {
    height: 100% !important
}

.timeline-container .vis-panel.vis-bottom {
    z-index: 20;
    font-size: 10px;
    padding-left: 3px
}

.timeline-container .vis-panel.vis-center {
    z-index: 100
}

.timeline-container .vis-grid {
    z-index: 10
}

.timeline-container .vis-time-axis .vis-text {
    padding: 0
}

.timeline-container .vis-item.vis-line {
    display: none
}

.timeline-container .vis-item.PHOTO {
    background-color: rgba(255, 255, 255, 0.6);
    z-index: 3
}

.timeline-container .vis-item.vis-selected.PHOTO-SELECTED {
    border: 3px;
    background-color: rgba(255, 255, 255, 0.9) !important
}

.timeline-container .vis-item.AUDIO {
    background-color: rgba(136, 34, 187, 0.6);
    z-index: 3
}

.timeline-container .vis-item.vis-selected.AUDIO-SELECTED {
    background-color: rgba(136, 34, 187, 0.9) !important;
    z-index: 3
}

.timeline-container .vis-item.MOTION {
    background-color: rgba(0, 170, 153, 0.6);
    z-index: 3
}

.timeline-container .vis-item.vis-selected.MOTION-SELECTED {
    border-top: 3px;
    background-color: rgba(0, 170, 153, 0.9) !important
}

.timeline-container .vis-item.vis-selected {
    z-index: 2
}

.timeline-container .vis-item.cursor {
    background-color: #3a94d0;
    z-index: 100
}

.timeline-container .vis-item:not(.cursor) {
    height: 45px;
    top: auto !important;
    bottom: 0
}

.timeline-container .vis-current-time {
    display: none
}

.cursor_content {
    font-size: 11px;
    text-align: center;
    height: 25px;
    margin-top: 0;
    width: 70px;
    color: #fff;
    position: absolute;
    top: -2px;
    left: -35px
}

.cursor_content > p {
    background: #3a94d0;
    border-radius: 4px;
    padding: 3px;
    text-align: center
}

.cursor_content > p:after {
    content: '';
    position: absolute;
    right: calc(50% - 6px);
    bottom: -7px;
    border: 5px solid transparent;
    border-top: 6px solid #3a94d0
}

.video-info-download-delete-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    padding-right: 24px;
    position: relative;
    z-index: 1001
}

.video-info {
    margin: 0 0 0 24px;
    color: #fff;
    max-width: 40%
}

.video-info.video-info-fullscreen-customization {
    position: absolute;
    bottom: 12px
}

.video-info .video-main-info {
    display: flex;
    flex-direction: column
}

.video-info .video-main-info p {
    font-size: 1.3rem
}

.video-info .video-main-info .till-subscription {
    margin: 8px 0
}

.video-info .video-main-info .live-label {
    padding: 0 8px;
    font-size: 12px;
    border-radius: 4px;
    background-color: #fff;
    color: #2B2830;
    font-weight: 500
}

.video-info .video-main-info div {
    display: flex;
    align-items: center
}

.video-info .video-main-info div h3 {
    margin: 0 10px 0 0;
    padding: 0;
    font-size: 24px
}

.video-info .subscription-container {
    display: flex;
    align-items: center
}

.video-info .subscription-container > div, .video-info .subscription-container div > div {
    display: flex;
    align-items: center
}

.video-info .subscription-container .share-black {
    background: url(../img/icon-share-white.svg) no-repeat center;
    width: 36px;
    height: 36px;
    background-size: 24px 24px
}

.video-info .subscription-container .share-black:hover {
    border-radius: 100%
}

.video-info .subscription-container .settings-black {
    background: url(../img/icon-settings-white.svg) no-repeat center;
    width: 36px;
    height: 36px;
    background-size: 24px 24px
}

.video-info .subscription-container .settings-black:hover {
    background-size: 24px 24px;
    border-radius: 100%
}

.subscription-button, .subscription-href-container {
    width: auto;
    height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #0a9;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 0 10px 0 10px;
    margin-right: 16px;
    outline: none;
    text-align: center
}

.subscription-button:hover, .subscription-href-container:hover {
    background: #00c4b0;
    color: #fff
}

.subscription-href-container {
    display: flex;
    align-items: center
}

hr {
    color: rgba(0, 0, 0, 0.877);
    margin-left: 144px;
    margin-right: 24px
}

.selected-recent-activity-item {
    padding: 5px;
    background-color: #6d69694a;
    border-radius: 4px
}

.recent-activity-container {
    width: 100%;
    padding-left: 144px;
    padding-right: 15px;
    position: relative
}

.recent-activity-container h3 {
    margin: 24px 0 16px 0;
    padding: 0;
    font-size: 24px
}

.recent-activity-container .recent-activity-menu {
    display: none;
    position: absolute;
    background-color: #fff;
    box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
    z-index: 500
}

.recent-activity-container .recent-activity-menu div {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px
}

.recent-activity-container .recent-activity-menu div a {
    font-weight: 400;
    padding: 0px 16px;
    color: #2B2830;
    margin: auto
}

.recent-activity-container .recent-activity-menu div:hover {
    background-color: rgba(75, 78, 78, 0.25)
}

.recent-activity-container .recent-activity {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: flex-start;
    position: relative
}

.recent-activity-container .recent-activity .recent-activity-date-header {
    width: 100%;
    font-size: 24px;
    padding: 0 0 0 5px
}

.recent-activity-container .recent-activity .info-and-menu-container {
    display: flex;
    justify-content: space-between;
    margin: 8px 0 0 0
}

.recent-activity-container .recent-activity .recent-activity-item-container {
    display: flex;
    flex-direction: column;
    margin: 14px 5px 10px 0;
    padding: 5px;
    width: 282px
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container {
    display: flex;
    flex-direction: column;
    max-width: 90%
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .top-info {
    display: flex;
    font-size: 14px;
    font-weight: 500
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .top-info p {
    padding-right: 5px;
    max-height: 19px;
    text-overflow: ellipsis;
    overflow: hidden
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .top-info p.info-time-label {
    min-width: fit-content;
    min-width: -moz-fit-content
}

p.info-time-label:hover {
    white-space: nowrap;
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .bottom-info {
    display: flex;
    align-items: center;
    font-size: 12px;
    font-weight: 400
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .bottom-info img {
    width: 20px;
    padding-right: 5px
}

@-moz-document url-prefix() {
    .recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .bottom-info img {
        width: 22px;
        padding-right: 5px
    }
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-info-container .bottom-info p {
    padding-right: 5px
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-item-menu-sign {
    width: 24px;
    border: none;
    background: none;
    font-size: 20px;
    margin: 0;
    padding: 0
}

.recent-activity-container .recent-activity .recent-activity-item-container .recent-activity-item-menu-sign:hover {
    color: #0a9
}

.recent-activity-container .recent-activity .recent-activity-item:hover {
    border: 2px solid #0a9
}

.recent-activity-container .recent-activity .recent-activity-item {
    width: 272px;
    height: 177px;
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    background: rgba(43, 40, 48, 0.6);
    border: 2px solid #fff
}

.recent-activity-container .recent-activity .recent-activity-item img {
    min-width: 100%;
    min-height: 100%;
    width: 100%;
    height: auto;
    position: absolute
}

.recent-activity-container .recent-activity .recent-activity-item .recent-activity-item-label {
    position: absolute;
    top: 8px;
    left: 8px;
    font-size: 9px;
    color: #fff;
    text-transform: uppercase;
    border-radius: 8px;
    padding: 2px 12px 2px 12px;
    margin: 0
}

.recent-activity-container .recent-activity .recent-activity-item .recent-activity-item-label-sound {
    background: #82b
}

.recent-activity-container .recent-activity .recent-activity-item .recent-activity-item-label-motion {
    background: #0a9
}

.recent-activity-container .recent-activity .recent-activity-item .recent-activity-item-label-fall {
    background: #aa2623
}

.dropdown ul li a {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px
}

.dropdown ul li a:hover {
    background-color: rgba(75, 78, 78, 0.25)
}

.dropdown ul {
    padding: 0;
    margin: 0
}

.recent-activity-container > .row {
    margin: 0
}

.grey-blocking-container {
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column
}

.loader {
    width: 100%;
    margin: 5px 0
}

.grey-blocking-container-activity {
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 1000
}

.spinner {
    margin: 0 auto;
    width: 100px;
    text-align: center
}

.spinner > div {
    width: 28px;
    height: 28px;
    background-color: #0a9;
    border-radius: 100%;
    display: inline-block;
    -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
    animation: sk-bouncedelay 1.4s infinite ease-in-out both
}

.spinner .bounce1 {
    -webkit-animation-delay: -0.32s;
    animation-delay: -0.32s
}

.spinner .bounce2 {
    -webkit-animation-delay: -0.16s;
    animation-delay: -0.16s
}

@-webkit-keyframes sk-bouncedelay {
    0%, 80%, 100% {
        -webkit-transform: scale(0)
    }
    40% {
        -webkit-transform: scale(1)
    }
}

@keyframes sk-bouncedelay {
    0%, 80%, 100% {
        -webkit-transform: scale(0);
        transform: scale(0)
    }
    40% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

body .alertify-notifier .ajs-message.ajs-warning {
    background: #82b;
    color: #fff
}

body .alertify-notifier .ajs-message.ajs-error {
    background: red;
    color: #fff
}

body .alertify-notifier .ajs-message.ajs-success {
    background: #0a9;
    color: #fff
}

.load-more-video {
    width: 272px;
    height: 180px;
    border-radius: 4px;
    border: 1px solid #2B2830;
    margin: 14px 14px 42px 0
}

.load-more-video:hover {
    background-color: #eeeeee
}

.no-padding {
    padding: 0;
    min-width: 100%;
    min-height: 100%;
    display: flex
}

.logo-and-reset-password-container {
    display: flex;
    width: 100%;
    min-height: 100vh
}

.logo-and-reset-password-container .left-logo-container {
    min-height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 33%;
    background-image: url(../images/login_bg.png);
    background-size: 100% 100%
}

.logo-and-reset-password-container .left-logo-container .logo {
    width: 220px;
    height: 140px;
    top: 14px;
    background: url(../images/logo_big_png.png) no-repeat 50% 50%;
    position: relative
}

.reset-container {
    width: 67%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center
}

.reset-password-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    word-break: break-word
}

.reset-password-container .reset-header {
    text-align: center;
    font-weight: 200;
    font-size: 36px;
    color: #000000;
    margin: 10px 15px
}

.reset-password-container .reset-info {
    margin: 10px 15px;
    max-width: 330px;
    text-align: center
}

.reset-password-container .hint-container {
    position: relative;
    margin-top: 8px;
    font-size: 14px
}

.reset-password-container .nickname-hint {
    top: 0;
    left: 0;
    color: red;
    display: none
}

.reset-password-container .nickname-hint + .green {
    color: #0a9
}

.reset-password-container .nickname-hint.visible {
    display: block
}

.reset-password-container .already-have-link {
    color: #000000;
    margin-top: 16px
}

.reset-password-container .already-have-link:hover {
    color: #0a9;
    cursor: pointer
}

.reset-password-container label {
    font-size: 12px;
    margin: 16px 0 0 0;
    color: rgba(0, 0, 0, 0.6)
}

.reset-password-container .change-nickname-input {
    margin: 10px 0 0 0;
    border: none;
    outline: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    height: 48px;
    font-size: 16px
}

.reset-password-container .change-nickname-input:hover, .reset-password-container .change-nickname-input:focus {
    border-bottom: 2px solid #0a9
}

.reset-password-container form {
    width: 330px;
    max-width: 80%;
    display: flex;
    flex-direction: column
}

.width300px {
    width: 300px
}

.password-show-hide-container {
    position: relative;
    width: 100%;
    height: 48px;
    margin-bottom: 5px
}

.password-show-hide-container input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding: 12px 12px 12px 0;
    box-sizing: border-box;
    border: none;
    background-color: #fff;
    border-bottom: 1px solid #ccc;
    outline: none
}

.password-show-hide-container .show-hide-icon {
    position: absolute;
    margin: 10px 0 0 0;
    top: 0;
    right: 0;
    transform: translate(-50%, 50%);
    width: 24px;
    height: 24px;
    cursor: pointer;
    background: url(../images/icon-hide.svg) no-repeat center
}

.password-show-hide-container .show-icon {
    background: url(../images/icon-show.svg) no-repeat center
}

.password-show-hide-container:hover input {
    border-bottom: 2px solid #0a9
}

.not-activated-email {
    width: 100%;
    font-size: 12px;
    color: #2B2830;
    text-align: center;
    margin: 12px
}

.not-activated-email a {
    color: #0a9
}

.change-password-button {
    width: auto;
    min-height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #0a9;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 0 12px 0 12px;
    margin: 24px 0 0 0;
    outline: none;
    text-align: center;
    line-height: 36px
}

.change-password-button:hover {
    background: #00c4b0;
    color: #fff
}

.change-password-button small {
    display: block;
    max-width: 100%;
    white-space: normal;
    line-height: 1.5;
    text-transform: initial
}

.delete-account-button {
    width: auto;
    min-height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #a00;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 0 12px 0 12px;
    margin: 24px 0 0 0;
    outline: none;
    text-align: center
}

.delete-account-button:hover {
    background: #c40000;
    color: #fff
}

.download-activity-button {
    width: auto;
    min-height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #82b;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 9px 12px;
    margin: 24px 0 0 0;
    outline: none;
    text-align: center
}

.download-activity-button:hover {
    background: #9826d1;
    color: #fff
}

.download-activity-button:focus {
    background: #9826d1;
    color: #fff;
    cursor: pointer;
    text-decoration: none;
    outline: none
}

.logout-button {
    width: auto;
    min-height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #3126d1;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 9px 12px;
    margin: 24px 0 0 0;
    outline: none;
    text-align: center
}

.logout-button:hover {
    background: #4136da;
    color: #fff
}

.logout-button:focus {
    background: #4136da;
    color: #fff;
    cursor: pointer;
    text-decoration: none;
    outline: none
}

.log-in-button {
    width: 100%;
    margin-top: 16px
}

.new-footer {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 1rem;
    text-align: center
}

.forgot-password, .new-account {
    font-size: 14px;
    text-transform: uppercase;
    font-weight: 500;
    margin: 32px 0 0 0
}

.forgot-password a, .new-account a {
    color: #2B2830
}

.new-account a {
    color: #0a9
}

.payment-success-img, .payment-fail-img {
    width: 120px;
    height: 120px;
    background-image: url(../images/success.png)
}

.payment-fail-img {
    background-image: url(../images/interrup.png)
}

.settings-paypal-popup-container {
    width: 100%;
    min-height: 100%;
    background: rgba(0, 0, 0, 0.7);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1000;
    display: none;
    flex-direction: row;
    justify-content: center;
    align-items: baseline
}

.settings-paypal-popup-container.visible {
    display: flex
}

.settings-paypal-popup-container .settings-paypal-popup {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #ffffff;
    width: fit-content;
    max-width: 100%
}

.settings-paypal-popup-container .settings-paypal-popup .grey-background {
    background-color: #EEEEEE;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center
}

.settings-paypal-popup-container .settings-paypal-popup .color-paypal {
    margin: 32px 150px 32px 150px;
    width: 100px;
    height: 24px;
    background: url(../img/color-paypal.svg) no-repeat center
}

.settings-paypal-popup-container .settings-paypal-popup .settings-popup-header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 0 32px 0;
    color: #000000;
    font-size: 20px;
    font-weight: 500
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container {
    max-width: 100%;
    flex-wrap: wrap;
    display: flex;
    justify-content: space-between
}

@media screen and (max-width: 767px) {
    .settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container {
        width: 100%
    }
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package {
    width: 150px;
    text-align: center;
    color: #000000;
    margin: 56px 16px 32px 16px
}

@media screen and (max-width: 767px) {
    .settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package {
        margin: 56px 1% 32px
    }
}

@media screen and (max-width: 652px) {
    .settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package {
        margin: 56px 2% 32px;
        width: 45%
    }
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package .price {
    font-size: 36px
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package .period {
    font-size: 18px;
    font-weight: 400
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package .purchase-button {
    width: auto;
    height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: #0a9;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.24), 0 0 2px 0 rgba(0, 0, 0, 0.12);
    border: none;
    color: #fff;
    border-radius: 4px;
    padding: 0 12px 0 12px;
    margin: 16px 0 0 0;
    outline: none;
    text-align: center
}

.settings-paypal-popup-container .settings-paypal-popup .popup-available-packages-container .package .purchase-button:hover {
    background: #00c4b0;
    color: #fff
}

.settings-paypal-popup-container .settings-paypal-popup .popup-note {
    text-align: center;
    font-size: 12px;
    color: #000000;
    margin: 0 0 24px 0
}

.popup-buttons {
    display: flex;
    justify-content: space-between;
    flex-direction: row
}

.popup-buttons div {
    display: flex;
    justify-content: flex-end
}

.popup-buttons .popup-button {
    width: auto;
    height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: inherit;
    border: none;
    color: black;
    border-radius: 4px;
    padding: 0 12px 0 12px;
    margin: 24px 8px 0 8px;
    outline: none;
    text-align: center
}

.popup-buttons .popup-button.cancel-popup-subscription-button {
    margin: 52px 0 32px 0;
    color: #0a9
}

.popup-buttons .popup-button:hover {
    color: #00c4b0;
    cursor: pointer
}

.popup-button {
    width: auto;
    height: 36px;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background-color: inherit;
    border: none;
    color: black;
    border-radius: 4px;
    padding: 0 12px 0 12px;
    margin: 24px 8px 0 8px;
    outline: none;
    text-align: center
}

.results-button {
    margin: 56px 0 32px 0
}

.results-button div {
    text-align: center;
    width: 100%
}

@media screen and (max-width: 767px) {
    .header {
        height: auto;
        display: flex;
        flex-direction: column;
        justify-content: center
    }

    .header .logo-container {
        display: flex;
        align-items: center;
        justify-content: space-between
    }

    .header .burger {
        display: block;
        margin-left: 100px
    }

    .header .menu, .header .user-cabinet {
        justify-content: flex-end;
        height: auto;
        display: none
    }

    .header .user-cabinet {
        justify-content: flex-end;
        display: none
    }

    .header .menu-item, .header .menu-item-username, .header .menu-item-username {
        width: 100%;
        display: block;
        text-align: center;
        padding: 10px 0;
        border-bottom: 1px solid white
    }

    .header .menu-item span.beta, .header .menu-item-username span.beta, .header .menu-item-username span.beta {
        position: relative
    }

    .logo-and-reset-password-container .left-logo-container {
        display: none
    }

    .logo-and-reset-password-container .reset-container {
        width: 100%
    }
}

@media screen and (max-width: 767px) {
    .top-controls {
        display: block;
        height: auto;
        position: relative
    }

    .top-controls .left-controls-container {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 50%
    }

    .top-controls .left-controls-container .select-period-container {
        display: flex;
        justify-content: flex-start
    }

    .top-controls .left-controls-container .period-buttons {
        display: none
    }

    .top-controls .right-controls-container {
        margin-left: 50%;
        width: 50%
    }
}

@media screen and (min-width: 1024px) {
    .middle-controls-stream-container {
        justify-content: center !important
    }

    .middle-controls-stream-container > * {
        margin-right: 40px
    }
}

@media screen and (max-width: 770px) {
    .video-info {
        display: block;
        position: relative;
        height: 120px
    }

    .video-info .video-main-info {
        padding: 0 0 0 15px;
        display: flex;
        flex-direction: column;
        justify-content: center !important
    }

    .video-info .subscription-container {
        margin: 0 auto;
        display: flex;
        justify-content: flex-start;
        position: absolute;
        bottom: 0;
        left: 0;
        padding: 0 15px 0 15px
    }

    .video-info .subscription-container img {
        margin-right: 5px
    }

    .recent-activity-container {
        padding: 0 0 0 15px
    }

    .home-available-cameras-container .home-available-cameras {
        padding-left: 15px
    }
}

@media screen and (max-width: 400px) {
    .play-stop-button {
        margin: 0 12px 0 12px !important
    }

    .next-video-button {
        margin-right: 24px !important
    }

    .prev-video-button {
        margin-left: 24px !important
    }
}

@media screen and (min-width: 1200px) and (max-width: 1440px) {
    .menu, .user-cabinet {
        padding-left: 20px
    }
}

.multi-select-checkbox {
    position: absolute;
    z-index: 1;
    right: 0;
    top: 0;
    padding: 7px;
    outline: none !important;
    -webkit-transition: opacity 0.2s ease-in-out;
    -moz-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    border: none;
    background: #2B2830;
    opacity: 0.4;
    border-radius: 0 4px;
    width: 32px;
    height: 32px;
    color: #fff
}

.multi-select-checkbox:hover, .multi-select-checkbox:active:hover {
    opacity: 0.6;
    color: #fff;
    background: #2B2830 !important
}

.multi-select-checkbox:focus, .multi-select-checkbox:active:focus, .multi-select-checkbox.focus {
    opacity: 0.4;
    color: #fff;
    background: #2B2830 !important
}

.multi-select-checkbox span.fa {
    border: 2px solid #dadada;
    display: block;
    color: #2B2830;
    border-radius: 4px;
    -webkit-transition: all 0.2s ease-in-out;
    -moz-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out
}

.multi-select-checkbox.active {
    background: rgba(43, 40, 48, 0.4);
    opacity: 1
}

.multi-select-checkbox.active span.fa {
    background: #00AA99;
    border-color: #00AA99;
    color: #DADADA
}

.multi-select-checkbox.active:hover, .multi-select-checkbox.active:active:hover {
    opacity: 1;
    color: #fff;
    background: rgba(43, 40, 48, 0.4) !important
}

.multi-select-checkbox.active:focus, .multi-select-checkbox.active:active:focus, .multi-select-checkbox.active.focus {
    opacity: 1;
    color: #fff;
    background: rgba(43, 40, 48, 0.4) !important
}

.video-quality-container {
    position: absolute;
    bottom: 15px;
    right: 15px
}

.select-hidden {
    display: none;
    visibility: hidden;
    padding-right: 10px
}

.select {
    cursor: pointer;
    display: inline-block;
    position: relative;
    font-size: 12px;
    color: #fff;
    width: 120px;
    height: 24px
}

.select-styled {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #292424;
    padding: 3px 6px;
    border-radius: 8px;
    border: 1px solid #a9a9a9;
    -webkit-transition: all 0.1s ease-in;
    -moz-transition: all 0.1s ease-in;
    transition: all 0.1s ease-in
}

.select-styled:after {
    content: "";
    width: 0;
    height: 0;
    border: 7px solid transparent;
    border-color: #fff transparent transparent transparent;
    position: absolute;
    top: calc(50% - 3px);
    right: 6px
}

.select-styled:hover {
    background-color: #241f1f
}

.select-styled:active, .select-styled.active {
    background-color: #1b1818;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0
}

.select-styled:active:after, .select-styled.active:after {
    top: calc(50% - 10px);
    border-color: transparent transparent #fff transparent
}

.select-options {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    left: 0;
    z-index: 999;
    margin: 0;
    padding: 0;
    list-style: none;
    background-color: #1b1818;
    border-radius: 8px;
    border: 1px solid #a9a9a9;
    border-top: 0;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    overflow: hidden
}

.select-options li {
    margin: 0;
    padding: 6px 0;
    text-indent: 15px;
    border-top: 1px solid #292424;
    -webkit-transition: all 0.15s ease-in;
    -moz-transition: all 0.15s ease-in;
    transition: all 0.15s ease-in
}

.select-options li:hover {
    color: #292424;
    background: #fff
}

.select-options li[rel="hide"] {
    display: none
}

.multi-links .delete-link {
    background: #FF2211;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.24), 0 0 2px rgba(0, 0, 0, 0.12);
    border-radius: 4px;
    line-height: 24px;
    font-weight: 500;
    font-size: 14px;
    text-transform: uppercase;
    color: #FFFFFF;
    padding: 6px 17px
}

.multi-links .delete-link i {
    display: inline-block;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-right: 8px
}

.multi-links .delete-link i:before {
    content: "";
    background: url("/img/delete.png");
    width: 24px;
    height: 24px;
    display: inline-block;
    margin: 0 0 -7px 0px
}

.multi-links .delete-link:hover {
    opacity: 0.8
}

.multi-links .select-link {
    line-height: 24px;
    font-weight: 500;
    font-size: 14px;
    text-transform: uppercase;
    color: rgba(0, 0, 0, 0.8);
    padding: 6px 17px;
    margin-right: 24px
}

.date-generation {
    font-size: 12px;
    font-weight: 300;
    margin: 10px 10px -10px 10px;
    text-align: center
}

.date-generation span {
    font-weight: 500;
    display: block
}

.modal-content {
    border-radius: 0;
    box-shadow: none;
    border: none
}

.modal-content .modal-header {
    background: #EEEEEE;
    color: #000000;
    text-align: center;
    border-bottom: 0
}

.modal-content .popup-buttons {
    justify-content: center
}

.modal-content .popup-buttons .popup-button.cancel-popup-subscription-button {
    margin: 0
}

#preloader, .preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.75);
    z-index: 1150
}

#loader {
    display: block;
    position: relative;
    left: 50%;
    top: 50%;
    width: 200px;
    height: 200px;
    margin: -100px 0 0 -100px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #9370DB;
    -webkit-animation: spin 2s linear infinite;
    animation: spin 2s linear infinite
}

#loader:before {
    content: "";
    position: absolute;
    top: 5px;
    left: 5px;
    right: 5px;
    bottom: 5px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #BA55D3;
    -webkit-animation: spin 3s linear infinite;
    animation: spin 3s linear infinite
}

#loader:after {
    content: "";
    position: absolute;
    top: 15px;
    left: 15px;
    right: 15px;
    bottom: 15px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #FF00FF;
    -webkit-animation: spin 1.5s linear infinite;
    animation: spin 1.5s linear infinite
}

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg)
    }
    100% {
        -webkit-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

@keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg)
    }
    100% {
        -webkit-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        transform: rotate(360deg)
    }
}

.canvas-container {
    background-color: transparent;
    position: absolute;
    left: 50%;
    transform: translate(-50%, 0%);
}

.canvas {
    width: 100%;
    height: 100%;
    background-color: transparent;
    /*border: 2px solid #ffffff;*/
}

.canvas-buttons-container {
    float: left;
    position: absolute;
    margin-left: 1%;
    margin-top: 1%;
    z-index: 1100;
}

.canvas-button {
    display: block;
    margin: 5px;
    width: 50px;
    min-width: 50px;
    height: 30px;
    font-size: 12pt;
    background: transparent;
    border: none !important;
    border-radius: 10px;
    color: rgb(0, 170, 153);
}

.canvas-button:hover {
    background-color: rgba(0, 170, 153, 0.3);
    width: 50px;
    height: 30px;
    transition: 0.5s
}

.roi-controls-container {
    position: absolute;
    display: none;
    z-index: 1010;
}

.roi-name-label {
    margin-left: 2px;
    background-color: transparent;
    border-color: transparent;
    color: white;
}

.canvas-roi-button {
    background-color: transparent;
    border-color: transparent;
    border-radius: 4px;
    width: 30px;
    height: 30px;
}

.canvas-edit-button {
    color: white;
    padding-left: 0px;
}

.canvas-delete-button {
    color: red;
}

.canvas-roi-button:hover {
    background-color: rgba(0, 170, 153, 0.3);
    width: 30px;
    height: 30px;
    transition: 0.5s
}

.fps-labels-container {
    display: block;
    height: fit-content;
    width: fit-content;
    margin-right: 20px;
    margin-left: auto;
}

.fps-label {
    display: flex;
    margin: 5px;
}

.fps-label label {
    color: white;
    font-size: 13px;
}

.fps-placeholder {
    width: 20px;
    margin-right: auto;
}

.file-chooser__dragndrop,
.file-chooser__uploading,
.file-chooser__success,
.file-chooser__error,
.file-chooser__icon {
    display: none;
}

.file-chooser {
    margin-top: 30px;
    width: 90%;
    font-size: 1.25rem;
    background-color: rgba(200, 218, 223, 0.6);
    position: relative;
    padding: 20px 20px;
    text-align: center;
    box-sizing: border-box;
    vertical-align: baseline;
    left: 50%;
    transform: translate(-50%, 0%);
}

.file-chooser.is-dragover {
    background-color: grey;
}

.file-chooser__input {
    width: 90%;
    /*max-width: 680px;*/
    text-align: center;
    margin: 0 auto;
    box-sizing: border-box;
    vertical-align: baseline;
}

.file-chooser.has-dnd {
    outline: 2px dashed #92b0b3;
    outline-offset: -10px;
    -webkit-transition: outline-offset .15s ease-in-out, background-color .15s linear;
    transition: outline-offset .15s ease-in-out, background-color .15s linear;
}

.file-chooser.has-dnd .file-chooser__dragndrop {
    display: inline;
    font-weight: 400;
}

.file-chooser__file {
    width: 1px;
    height: 1px;
    /*width: 100%;*/
    /*height: 100%;*/
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
}

.file-chooser__button {
    font-weight: 700;
    color: #e5edf1;
    background-color: #39bfd3;
    display: none;
    padding: 8px 16px;
    margin: 40px auto 0;
}

.file-chooser__file + label {
    font-family: "Roboto", sans-serif;
    max-width: 80%;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: pointer;
    display: inline-block;
    overflow: hidden;
}

.file-chooser.has-dnd .file-chooser__icon {
    width: 100%;
    height: 40px;
    fill: #92b0b3;
    display: block;
    margin-bottom: 20px;
}

.file-chooser.is-uploading .file-chooser__input {
    visibility: none;
}
.file-chooser.is-uploading .file-chooser__uploading {
    display: block;
}