html,
body,
.framework7-root {
    position: relative;
    height: 100%;
    width: 100%;
    overflow-x: hidden;
}

.framework7-root {
    overflow: hidden;
    box-sizing: border-box;
}

@media (width: 1024px) and (height: 691px) and (orientation: landscape) {

    html,
    body,
    .framework7-root {
        height: 671px;
    }
}

@media (width: 1024px) and (height: 692px) and (orientation: landscape) {

    html,
    body,
    .framework7-root {
        height: 672px;
    }
}

@media (width: 1024px) and (height: 691px) and (orientation: landscape) {

    .ios,
    .ios body,
    .ios .framework7-root {
        height: 671px;
    }
}

@media (width: 1024px) and (height: 692px) and (orientation: landscape) {

    .ios,
    .ios body,
    .ios .framework7-root {
        height: 672px;
    }
}


.views,
.view {
    position: relative;
    height: 100%;
    z-index: 5000;
    overflow: hidden;
    box-sizing: border-box;
}

/* === Pages === */
:root {
    --f7-page-master-width: 320px;
    --f7-page-master-border-color: rgba(0, 0, 0, 0.1);
    --f7-page-master-border-width: 1px;
}

.ios {
    --f7-page-bg-color: #efeff4;
    --f7-page-transition-duration: 400ms;
    --f7-page-swipeback-transition-duration: 400ms;
}

.md {
    --f7-page-bg-color: #fff;
    --f7-page-transition-duration: 250ms;
    --f7-page-swipeback-transition-duration: 400ms;
}

.theme-dark {
    --f7-page-bg-color: #171717;
    --f7-page-master-border-color: rgba(255, 255, 255, 0.1);
}

.pages {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.page {
    box-sizing: border-box;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: translate3d(0, 0, 0);
    background-color: var(--f7-page-bg-color);
}

.page.stacked {
    display: none;
}

/* .page-with-navbar-large-collapsed {
    --f7-navbar-large-collapse-progress: 1;
  } */
.page-previous {
    pointer-events: none;
}

.page-content {
    will-change: scroll-position;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
    height: 100%;
    position: relative;
    z-index: 1;
}

.page-transitioning,
.page-transitioning .page-shadow-effect,
.page-transitioning .page-opacity-effect {
    transition-duration: var(--f7-page-transition-duration);
}

.page-transitioning-swipeback,
.page-transitioning-swipeback .page-shadow-effect,
.page-transitioning-swipeback .page-opacity-effect {
    transition-duration: var(--f7-page-swipeback-transition-duration);
}

.router-transition-forward .page-next,
.router-transition-backward .page-next,
.router-transition-forward .page-current,
.router-transition-backward .page-current,
.router-transition-forward .page-previous:not(.stacked),
.router-transition-backward .page-previous:not(.stacked) {
    pointer-events: none;
}

.page-shadow-effect {
    position: absolute;
    top: 0;
    width: 16px;
    bottom: 0;
    z-index: -1;
    content: '';
    opacity: 0;
    right: 100%;
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.01) 50%, rgba(0, 0, 0, 0.2) 100%);
}

.page-opacity-effect {
    position: absolute;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.1);
    width: 100%;
    bottom: 0;
    content: '';
    opacity: 0;
    z-index: 10000;
}

.ios .page-previous {
    transform: translate3d(-20%, 0, 0);
}

.ios .page-next {
    transform: translate3d(100%, 0, 0);
}

.ios .page-previous .page-opacity-effect {
    opacity: 1;
}

.ios .page-previous:after {
    opacity: 1;
}

.ios .page-current .page-shadow-effect {
    opacity: 1;
}

.ios .router-transition-forward .page-next,
.ios .router-transition-forward .page-current {
    will-change: transform;
}

.ios .router-transition-forward .page-next {
    animation: ios-page-next-to-current var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-forward .page-next:before {
    position: absolute;
    top: 0;
    width: 16px;
    bottom: 0;
    z-index: -1;
    content: '';
    opacity: 0;
    right: 100%;
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.01) 50%, rgba(0, 0, 0, 0.2) 100%);
    animation: ios-page-element-fade-in var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-forward .page-current {
    animation: ios-page-current-to-previous var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-forward .page-current:after {
    position: absolute;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.1);
    width: 100%;
    bottom: 0;
    content: '';
    opacity: 0;
    z-index: 10000;
    animation: ios-page-element-fade-in var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-backward .page-previous,
.ios .router-transition-backward .page-current {
    will-change: transform;
}

.ios .router-transition-backward .page-previous {
    animation: ios-page-previous-to-current var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-backward .page-previous:after {
    position: absolute;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.1);
    width: 100%;
    bottom: 0;
    content: '';
    opacity: 0;
    z-index: 10000;
    animation: ios-page-element-fade-out var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-backward .page-current {
    animation: ios-page-current-to-next var(--f7-page-transition-duration) forwards;
}

.ios .router-transition-backward .page-current:before {
    position: absolute;
    top: 0;
    width: 16px;
    bottom: 0;
    z-index: -1;
    content: '';
    opacity: 0;
    right: 100%;
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 10%, rgba(0, 0, 0, 0.01) 50%, rgba(0, 0, 0, 0.2) 100%);
    animation: ios-page-element-fade-out var(--f7-page-transition-duration) forwards;
}

/* .ios .router-dynamic-navbar-inside .page-shadow-effect,
  .ios .router-dynamic-navbar-inside .page-opacity-effect {
    top: var(--f7-navbar-height);
  }
  .ios .router-dynamic-navbar-inside .page-next:before,
  .ios .router-dynamic-navbar-inside .page-current:after,
  .ios .router-dynamic-navbar-inside .page-current:before,
  .ios .router-dynamic-navbar-inside .page-previous:after {
    top: var(--f7-navbar-height);
  } */
@keyframes ios-page-next-to-current {
    from {
        transform: translate3d(100%, 0, 0);
    }

    to {
        transform: translate3d(0%, 0, 0);
    }
}

@keyframes ios-page-previous-to-current {
    from {
        transform: translate3d(-20%, 0, 0);
    }

    to {
        transform: translate3d(0%, 0, 0);
    }
}

@keyframes ios-page-current-to-previous {
    from {
        transform: translate3d(0, 0, 0);
    }

    to {
        transform: translate3d(-20%, 0, 0);
    }
}

@keyframes ios-page-current-to-next {
    from {
        transform: translate3d(0, 0, 0);
    }

    to {
        transform: translate3d(100%, 0, 0);
    }
}

@keyframes ios-page-element-fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes ios-page-element-fade-out {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

.md .page-next {
    transform: translate3d(0, 56px, 0);
    opacity: 0;
    pointer-events: none;
}

.md .page-next.page-next-on-right {
    transform: translate3d(100%, 0, 0);
}

.md .router-transition-forward .page-next {
    will-change: transform, opacity;
    animation: md-page-next-to-current var(--f7-page-transition-duration) forwards;
}

.md .router-transition-forward .page-current {
    animation: none;
}

.md .router-transition-backward .page-current {
    will-change: transform, opacity;
    animation: md-page-current-to-next var(--f7-page-transition-duration) forwards;
}

.md .router-transition-backward .page-previous {
    animation: none;
}

@keyframes md-page-next-to-current {
    from {
        transform: translate3d(0, 56px, 0);
        opacity: 0;
    }

    to {
        transform: translate3d(0, 0px, 0);
        opacity: 1;
    }
}

@keyframes md-page-current-to-next {
    from {
        transform: translate3d(0, 0, 0);
        opacity: 1;
    }

    to {
        transform: translate3d(0, 56px, 0);
        opacity: 0;
    }
}

.view:not(.view-master-detail) .page-master-stacked {
    display: none;
}

/* .view:not(.view-master-detail) .navbar-master-stacked {
    display: none;
  } */
.view-master-detail .page-master,
.view-master-detail .navbar-master {
    width: var(--f7-page-master-width);
    --f7-safe-area-right: 0px;
    --f7-safe-area-outer-right: 0px;
    border-right: var(--f7-page-master-border-width) solid var(--f7-page-master-border-color);
}

.view-master-detail .page-master-detail,
.view-master-detail .navbar-master-detail {
    width: calc(100% - var(--f7-page-master-width));
    --f7-safe-area-left: 0px;
    --f7-safe-area-outer-left: 0px;
    left: var(--f7-page-master-width);
}

.view-master-detail .page-master {
    z-index: 1;
    transform: none;
    pointer-events: auto;
}

.view-master-detail .page-master:before,
.view-master-detail .page-master:after {
    display: none;
}

.view-master-detail.router-transition .page-master {
    animation: none;
}