﻿
.show-on-phone {
    display: none !important;
}

.grid-12 {
    grid-column: span 12 !important;
}

.txt-main {
    color: var(--bs-main);
}

.scanner-divider {
    width: var(--px-240);
    height: 3px;
    background-color: red;
    opacity: 0.7;
    box-shadow: 0px 0px 8px 10px rgba(170, 11, 23, 0.49);
    top: 50%;
    left: 50%;
    transform: translateX(-50%);
    position: absolute;
    animation-name: scan;
    animation-duration: 4s;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    animation-play-state: paused;
    animation-play-state: running;
}

i.fa-house {
    color: var(--bs-main-500) !important;
}

i.fa-regular.fa-circle-check {
    color: #8fd3ff !important;
}

    i.fa-regular.fa-circle-check.today {
        color: #ffcd00 !important;
    }

i.fa-calendar-exclamation {
    color: var(--bs-orange) !important;
}

i.fa-right-to-bracket {
    color: #A0522D !important;
}

@media only screen and (max-width: 480px) {
    /* Styles for extra small devices */
    :root {
        --scale: 86;
    }

    * {
        touch-action: manipulation;
    }

    .append-data-setting .container-switch-setting {
        width: 100%;
    }

    .group-btn-pos-right {
    }

    .btn-show-confirm-portal {
        font: normal normal 500 var(--s-13);
    }

    .container-switch-setting .btn-switch-tab {
        height: var(--px-200);
    }

    .form-container .info_row {
        padding: var(--px-2) var(--px-8);
    }

    .frame-languages {
        max-height: var(--px-80);
    }

    .btn-signature-side-right {
        width: var(--px-200);
    }

        .btn-signature-side-right i {
            font-size: var(--px-20);
        }

    .home-checkin-screen-large {
        display: none !important;
    }

    .body-select-languages .frame-qrcode {
        display: none !important;
    }

    .back-regis-list {
        padding: 0 var(--px-20);
    }

    .grid-3 {
        /*grid-column: span 4;*/
    }

    .grid-4 {
        grid-column: span 6;
    }

    .hidden-on-phone {
        display: none !important;
    }

    .show-on-phone {
        display: flex !important;
    }

    .body-registration .group-ticket-view .box-regis {
        grid-template-columns: var(--px-60) repeat(2, minmax(var(--px-160), var(--px-228)));
    }

    .signature {
        flex: 1;
        /*min-width: 100%;*/
    }

    .header-portal-checkin {
        flex-direction: column;
    }

    div.form-upload-image {
        height: var(--px-400);
    }

    .logo-hotel span.name {
        max-width: var(--px-140);
    }

    .filter_input {
        flex: 1;
        justify-content: space-between;
    }

    #filter-list.active {
        width: 100%;
    }

    .body-registration .group-ticket-view {
        width: fit-content;
    }

    .transform-page.home,
    .transform-page.typing {
        min-width: 100%;
        max-width: 100%;
    }

    .frame-languages .form-select-language {
        grid-template-columns: repeat(4, 1fr) !important;
    }

    .footer-portal.selected-languages-show {
        display: flex;
    }

    .portal-checkin .pin-form-keypad {
        grid-template-rows: repeat(4, var(--px-100));
        grid-template-columns: repeat(3, 1fr);
    }

    .keyboard-pin .pin-form-keypad button {
        font: normal normal 600 var(--s-38);
    }

    #scan-qrcode-body canvas {
        max-height: var(--px-260)
    }

    .quick-search-full {
        width: 95%;
        height: 90%;
        justify-content: center;
        flex-direction: column;
    }

    .search-left-area {
        padding: var(--px-24);
    }

    .quick-search-full .search-form.active {
        min-width: unset;
    }

    .tab-seach-select-manage {
        padding: var(--px-24);
    }

    .setting-container.checkin-content {
        flex-direction: column;
    }

    .header-portal-checkin .checkin-start {
        position: unset;
    }

    .header-portal-checkin .checkin-end .name {
        text-align: center;
    }
}

@media only screen and (min-width: 481px) and (max-width: 768px) {
    /* Styles for small devices */
    :root {
        --scale: 88;
    }

    * {
        touch-action: manipulation;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1024px) {
    /* Styles for medium devices */
    :root {
        --scale: 90;
    }

    * {
        touch-action: manipulation;
    }

    #upload-image-or-sign .staff.signature {
        min-height: var(--px-500);
    }
}

@media only screen and (min-width: 1025px) and (max-width: 1200px) {
    /* Styles for large devices */
    :root {
        --scale: 92;
    }

    * {
        touch-action: manipulation;
    }
}

@media only screen and (min-width: 1201px) {
    /* Styles for extra large devices */
    :root {
        --scale: 94;
    }

    * {
        touch-action: manipulation;
    }
}

@media only screen and (orientation: portrait) {
    /* Styles for portrait orientation */
    :root {
    }
}

@media only screen and (orientation: landscape) {
    /* Styles for landscape orientation */
    :root {
    }
}

@media only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi) {
    /* Styles for retina displays */
    :root {
    }
}

@media (prefers-color-scheme: dark) {
    /* Styles for dark mode */
}

@media (prefers-reduced-motion: reduce) {
    /* Styles for reduced motion preference */
}

@media only screen and (min-width: 1400px) {
    /* Custom styles for screens larger than 1400px */
    :root {
        --scale: 100;
    }
}

@keyframes pulse {
    from {
        box-shadow: 0 0 0 0 #AAAAAA;
    }
}

@keyframes scale-click {
    from {
        transform: scale(.9);
    }

    to {
        transform: scale(1);
    }
}

@-webkit-keyframes scanner {
    0% {
        bottom: 90%;
    }

    50% {
        bottom: 10%;
    }

    100% {
        bottom: 90%;
    }
}

@-moz-keyframes scanner {
    0% {
        bottom: 90%;
    }

    50% {
        bottom: 10%;
    }

    100% {
        bottom: 90%;
    }
}

@-o-keyframes scanner {
    0% {
        bottom: 90%;
    }

    50% {
        bottom: 10%;
    }

    100% {
        bottom: 90%;
    }
}

@keyframes scanner {
    0% {
        bottom: 90%;
    }

    50% {
        bottom: 10%;
    }

    100% {
        bottom: 90%;
    }
}

@import url("https://fonts.googleapis.com/css?family=Exo:400,700");

.area {
    background: #4e54c8;
    background: -webkit-linear-gradient(to left, #8f94fb, #4e54c8);
    width: 100%;
    height: 100vh;
}

.circles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

    .circles li {
        position: absolute;
        display: block;
        list-style: none;
        width: 20px;
        height: 20px;
        background: #d9657040;
        animation: animate 25s linear infinite;
        bottom: -150px;
        border-radius: 100%;
    }

        .circles li:nth-child(1) {
            left: 25%;
            width: 80px;
            height: 80px;
            animation-delay: 0s;
            background: #f29c23;
        }

        .circles li:nth-child(2) {
            left: 10%;
            width: 20px;
            height: 20px;
            animation-delay: 2s;
            background: #65bcf7;
            animation-duration: 12s;
        }

        .circles li:nth-child(3) {
            left: 70%;
            width: 20px;
            background: #162c88;
            height: 20px;
            animation-delay: 4s;
        }

        .circles li:nth-child(4) {
            left: 40%;
            width: 60px;
            height: 60px;
            animation-delay: 0s;
            background: #eef7ff;
            animation-duration: 18s;
        }

        .circles li:nth-child(5) {
            left: 65%;
            width: 20px;
            background: #eef7ff;
            height: 20px;
            animation-delay: 0s;
        }

        .circles li:nth-child(6) {
            left: 75%;
            width: 110px;
            background: #f29c23;
            height: 110px;
            animation-delay: 3s;
        }

        .circles li:nth-child(7) {
            left: 35%;
            width: 150px;
            height: 150px;
            background: #65bcf7;
            animation-delay: 7s;
        }

        .circles li:nth-child(8) {
            left: 50%;
            width: 25px;
            height: 25px;
            background: #162c88;
            animation-delay: 15s;
            animation-duration: 45s;
        }

        .circles li:nth-child(9) {
            left: 20%;
            width: 15px;
            height: 15px;
            animation-delay: 2s;
            animation-duration: 35s;
        }

        .circles li:nth-child(10) {
            left: 85%;
            width: 150px;
            background: #162c88;
            height: 150px;
            animation-delay: 0s;
            animation-duration: 11s;
        }

@keyframes animate {
    0% {
        transform: translateY(0) rotate(0deg);
        opacity: .3;
    }

    100% {
        transform: translateY(-1000px) rotate(720deg);
        opacity: 0;
    }
}

@keyframes scan {
    0% {
        box-shadow: 0px 0px 8px 10px rgba(170, 11, 23, 0.49);
        top: 50%;
    }

    25% {
        box-shadow: 0px 6px 8px 10px rgba(170, 11, 23, 0.49);
        top: calc(50% - var(--px-120));
    }

    75% {
        box-shadow: 0px -6px 8px 10px rgba(170, 11, 23, 0.49);
        top: calc(50% + var(--px-120));
    }
}

@keyframes button-pulse {
    from {
        box-shadow: 0 0 0 0 var(--color-green-light);
    }

    to {
        box-shadow: 0 0 0 8px rgba(255, 255, 255, 0);
    }
}

@keyframes fade-up-out {
    to {
        opacity: 0;
        transform: translateY(-40%);
    }
}

@keyframes fade-up-in {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes load-right {
    0% {
        left: -100%;
    }

    50% {
        left: 0;
    }

    100% {
        left: 100%;
    }
}
