﻿:root {
    --gfpal-white: #FFFFFF;
    --gfpal-black: #000000;
    --gfpal-red: #E02B20;
    --gfpal-green: #21A884;
    --gfpal-green-light: #21A88440;
    --gfpal-blue: #215AA8;
    --gfpal-bluevibrant: #0078D7;
    --gfpal-yellow: #FCD637;
    --gfpal-orange: #F05E2B;
    --gfpal-O1: #FFEDD5;
    --gfpal-M1: #ED2B51;
    --gfpal-M2: #D42556;
    --gfpal-M3: #BB265D;
    --gfpal-M4: #8B3C96;
    --gfpal-M5: #5D3C96;
    --gfpal-BG1: #111629;
    --gfpal-BG2: #64748B;
    --gfpal-BG3: #BECEE4;
    --gfpal-BG4: #F2F4F8;
}

.unselectable {
    -webkit-user-select: none; /* Safari */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
    user-select: none; /* Non-prefixed version, currently supported by Chrome, Opera, and Edge */
}

@keyframes pwainstall {
    0% {
        padding-top: 0px;
        color: var(--gfpal-BG1);
    }

    50% {
        padding-top: 4px;
        color: var(--gfpal-bluevibrant);
    }

    100% {
        padding-top: 0px;
        color: var(--gfpal-BG1);
    }
}

.r_pwainstallbutton {
    position: fixed;
    left: 15px;
    bottom: 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    z-index: 9999;
}

    .r_pwainstallbutton .icon {
        background-color: var(--gfpal-white);
        color: var(--gfpal-BG1);
        width: 60px;
        height: 60px;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        margin-bottom: 4px;
        animation: pwainstall 1s linear infinite;
    }

        .r_pwainstallbutton .icon i {
            font-size: 32px;
        }

    .r_pwainstallbutton .text {
        color: var(--gfpal-white);
        font-size: 12px;
    }
::placeholder {
    color: #ccc;
}

.scrollbox {
    opacity: 1;
}

    .scrollbox.visible {
        /*transition: opacity 100ms;*/
        opacity: 1;
    }

/* Width percentage shortcuts */

.p100 {
    width: 100% !important;
}

.p75 {
    width: 75% !important;
}

.p50 {
    width: 50% !important;
}

.p33 {
    width:33.3% !important;
}

.p25 {
    width: 25% !important;
}

.p20 {
    width: 20% !important;
}

.p10 {
    width: 10% !important;
}

/* Text alignment shortcuts */

.ar {
    text-align: right !important;
}

.al {
    text-align: left !important;
}

.ac {
    text-align: center !important;
}

/* Absolute width shortcuts */
.w10 {
    width: 10px;
}

.w20 {
    width: 20px;
}

.w40 {
    width: 40px;
}

.w60 {
    width: 60px;
}

.w80 {
    width: 80px;
}

.w100 {
    width: 100px;
}

.w120 {
    width: 120px;
}

.w140 {
    width: 140px;
}

.w150 {
    width: 150px;
}

.w175 {
    width: 175px;
}

.w200 {
    width: 200px;
}

.w300 {
    width: 300px;
}

.w400 {
    width: 400px;
}

.w500 {
    width: 400px;
}

/* Padding right shortcuts */

.pr4 {
    padding-right: 4px;
}

.pr8 {
    box-sizing: border-box;
    padding-right: 10px !important;
}

.pr10 {
    box-sizing: border-box;
    padding-right: 10px !important;
}

.pr20 {
    box-sizing:border-box;
    padding-right:20px !important;
}

.pb8 {
    padding-bottom: 4px;
}

.pt8 {
    padding-top: 8px;
}

/* Margin shortcuts */

.mb-s {
    margin-bottom: 8px;
}

.mr-s {
    margin-right: 15px;
}

.mr-m {
    margin-right: 30px;
}

.mt-s {
    margin-top: 8px;
}

.mr8 {
    margin-right: 8px;
}

/* Img */

img.smallicon16 {
    width: 16px;
    height: 16px;
}

/* Font style shortcuts */

.fbold {
    font-weight: bold;
}

    .fbold.marginbottom {
        margin-bottom: 4px;
    }

.flight {
    color: #555;
}

.fsmallbold {
    font-weight: bold;
    font-size: 9pt;
}

.fsmaller {
    font-size: 10pt;
}

.fsmall {
    font-size: 10pt;
}

.ourgreen {
    color: #21a884;
}

/* Partial refreshing */

.refreshable {
    opacity: 0;
}

.attention {
    transition: opacity 0.5s;
    opacity: 1 !important;
}

/* Age labels */

.g_agelabel {
    background-color: black;
    color: white;
    box-sizing: border-box;
    padding: 4px 20px;
    border-radius: 4px;
    font-size: 10pt;
    text-align:center;
}

.g_agelabel.style-green {
    background-color: #33b378;
}

.g_agelabel.style-red {
    background-color: #e54d40;
}


.g_when {
    background-color: black;
    color: white;
    box-sizing: border-box;
    padding: 4px 20px;
    border-radius: 4px;
    font-size: 10pt;
    text-align: center;
    width: 120px;
}

    .g_when.scanner {
        padding: 3px 2px !important;
        height: 20px;
        border-radius: 4px;
        font-size: 9pt;
        font-weight: bold;
        width: 100px;
    }

    .g_when.style-today {
        background-color: var(--gfpal-green);
        color: white;
    }

    .g_when.style-yesterday {
        background-color: #FF8900;
        color: white;
    }

    .g_when.style-nextweek {
        background-color: black;
        color: white;
    }

    .g_when.style-history {
        background-color: #D63F3F;
        color: white;
    }

    .g_when.style-history {
        background-color: #D63F3F;
        color: white;
    }

.g_number {
    text-align: right;
    font-weight: bold;
    white-space: nowrap;
}

.g_midnumber {
    font-weight: bold;
    font-size: 14pt;
    display: flex;
    align-items: center;
}

.g_status {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

    .g_status img {
        width: 20px;
    }

    .g_status .withlabel {
        display: flex;
        justify-content: center;
        align-items: center;
        border: 1px solid #21a884;
        box-sizing: border-box;
        padding: 6px 15px;
        border-radius: 4px;
        color: #21a884;
    }

        .g_status .withlabel img {
            margin-right: 10px;
            width:20px;
        }

        .g_status .withlabel.crossdock {
            border: 1px solid #9F6819;
            color: #9F6819;
        }

            .g_status .withlabel.crossdock img {
                width: 24px;
            }

.r_batch.edit .g_status .withlabel {
    position: fixed;
    top: 200px;
    right: 50px;
}





.g_avatar {
    box-sizing: border-box;
}

    .g_avatar .employee {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        flex-direction: column;
        cursor: pointer;
        outline:0;
    }

        .g_avatar .employee .avatar img {
            width: 60px;
            height: 60px;
            border-radius: 50%;
            outline: 0;
        }

        .g_avatar .employee .avatar {
            box-sizing: border-box;
            border: 1px solid #bababa;
            border-radius: 50%;
            width: 60px;
            height: 60px;
            display: flex;
            align-items: center;
            justify-content: center;
            outline: 0;
        }

        .g_avatar .employee.notassigned img {
            width: 60px;
            height: 60px;
            border-radius: 50%;
            outline: 0;
        }

        .g_avatar .employee.selected .avatar {
            border: 3px solid #21A884;
            opacity: 1.0;
            outline: 0;
        }

        .g_avatar .employee .name {
            font-size: 9pt;
            text-align: center;
        }

    .g_avatar .avatar {
        /*outline: 2px solid #097ffa;*/
        box-shadow: 0 0 0 2px #097ffa;
    }

    .g_avatar.mid .employee .avatar img {
        width: 40px;
        height: 40px;
        outline: 0;
    }

    .g_avatar.mid .employee .avatar {
        width: 40px;
        height: 40px;
    }

._longpress_productid {
    user-select: none; /* supported by Chrome and Opera */
    -webkit-user-select: none; /* Safari */
    -khtml-user-select: none; /* Konqueror HTML */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
}

.g_fail {
    background-color: red;
    color: white;
    box-sizing: border-box;
    padding: 4px 12px;
    border-radius: 4px;
}

.g_location {
    box-sizing: border-box;
    padding: 2px 8px;
    border-radius: 4px;
}

    .g_location.locationtype-pick {
        background-color: #fcd639;
        color: #000;
    }

    .g_location.locationtype-bulk {
        background-color: #2378E3;
        color: white;
    }

    .g_location.locationtype-receive {
        background-color: var(--gfpal-green);
        color: white;
    }

    .g_location.locationtype-crossdock {
        background-color: #444;
        color: white;
    }

    .g_location.locationtype-ext {
        background-color: var(--gfpal-green);
        color: white;
    }

    .g_location.locationtype-unspecified {
        background-color: #a121a8;
        color: white;
    }




.g_alphaicon {
    position: relative;
    margin-right: 10px;
    margin-top: 6px;
}

    .g_alphaicon.smaller {
        transform: scale(80%);
    }

    .g_alphaicon img {
        width: 26px;
        height: 26px;
    }

    .g_alphaicon .alpha {
        position: absolute;
        color: white;
        top: 7px;
        left: 8px;
        font-weight: bold;
    }



.g_batchinfo {
    color: #888;
    font-size: 10pt;
    line-height: 24px;
    font-weight:normal;
}


.r_boxes.scanner {
    display: flex;
    margin-top: 8px;
}

    .r_boxes.scanner .box {
        position: relative;
        width: 50px;
    }

        .r_boxes.scanner .box img {
            width: 40px;
            height: 40px;
            margin-left: 5px;
        }

        .r_boxes.scanner .box .imgdefault {
            display: block;
        }

        .r_boxes.scanner .box .imgselected {
            display: none;
        }

        .r_boxes.scanner .box.selected .imgdefault {
            display: none;
        }

        .r_boxes.scanner .box.selected .imgselected {
            display: block;
        }

        .r_boxes.scanner .box .number {
            position: absolute;
            top: 21px;
            left: 5px;
            width: 40px;
            text-align: center;
            font-size: 10pt;
        }

        .r_boxes.scanner .box.selected .number {
            color: white;
        }

        .r_boxes.scanner .box .name {
            width: 50px;
            height: 10px;
            font-size: 7pt;
            text-align: center;
            overflow: hidden;
            color: #888;
            margin-top: 4px;
        }


.navpane-wrapper {
    position: fixed;
    z-index: 10;
    background-color: #394447;
    left: 0;
    top: 0;
    height: 100vh;
    width: 250px;
}

.navpane {
    position: fixed;
    height: 100%;
    top: 0;
    padding-top: 60px;
    /*background-color: #394447;*/
    color: white;
    box-sizing: border-box;
    z-index: 90;
    overflow: auto;
    width: 250px;
}

.navpane-wrapper .navitem.active a {
    font-weight: bold;
    color: #fcd637 !important;
    width:100%;
}

.navsegment {
    box-sizing: border-box;
    margin: 20px 0 40px 20px;
    font-size: 11pt;
}

    .navsegment .icontainer {
        width: 23px;
        display: inline-block;
    }

    .navsegment .title {
        box-sizing: border-box;
        margin: 15px 0;
        text-transform: uppercase;
        font-size: 10pt;
        font-weight: bold;
    }


        .navsegment .title i {
            font-weight: normal;
            margin-right: 8px;
            width: 15px;
        }

    .navsegment .navitem {
        box-sizing: border-box;
        display: flex;
        flex-wrap: nowrap;
        justify-content: flex-start;
        align-items: flex-start;
        margin: 3px 0 7px 15px;
        cursor: pointer;
    }

        .navsegment .navitem:hover .caption {
            color: #fcd637;
        }

    .navsegment span.icon {
        display: none;
        background-repeat: no-repeat;
        background-size: 16px 16px;
        width: 20px;
        height: 20px;
    }

    .navsegment .caption {
        box-sizing: border-box;
        overflow: hidden;
        margin: 3px 0 0 8px;
        color: #dcdcdc;
        font-size: 10pt;
        text-decoration: none
    }

.r_tinyurl {
    font-size: 10pt;
    color: #21a884;
    cursor: pointer;
}

#googlemap {
    height: 300px !important;
}

._copytoclipboard {
    position: relative;
}

    ._copytoclipboard.copied:after {
        position: absolute;
        content: "\2714";
        width: 20px;
        height: 20px;
        top: -3px;
    }

.qrdigits {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-top: 10px;
}

    .qrdigits .digit {
        background-color: white;
        border-radius: 4px;
        width: 30px;
        height: 30px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: bold;
    }

.qr .interior {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .qr .interior .activated {
        position: absolute;
        background-color: white;
        width: 60px;
        height: 60px;
        border: 5px solid green;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .qr .interior .activated {
        color: green;
        font-size: 20pt;
    }

.r_skutype {
    background-color: black;
    color: white;
    height: 22px;
    width: 22px;
    border-radius: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
}

.r_keyboardbuffer {
    display: none;
    position: fixed;
    top: 0;
    z-index: 9999;
    width: 100%;
    justify-content: center;
    margin-top: 10px;
}

    .r_keyboardbuffer .content {
        background-color: white;
        color: black;
        padding: 10px 30px;
        border-radius: 20px;
        box-shadow: 4px 4px 4px rgba(0,0,0,0.25);
    }

















.g_block {
    margin: 0 10px;
    display: flex;
}

.g_gutter {
    width: 15px;
}

.g_presser {
    background-color: white;
    display: flex;
    align-items: center;
    /*border-radius: 4px;*/
    box-sizing: border-box;
    padding: 6px 10px;
    font-size: 11pt;
    font-weight: bold;
    cursor: pointer;
}

    .g_presser[data-type='text'] input[type='text'] {
        border: 0;
        outline: 0;
        font-weight: bold;
    }

        .g_presser[data-type='text'] input[type='text']::placeholder {
            font-weight: normal;
        }


.manualinputoverlay {
    z-index: 2;
}

.sc_selectform {
    z-index: 99999 !important;
}

.gf_websocketspecs {
    display: none;
}

.r_chart.onlinestatus .urltitle {
    text-align: center;
}


@keyframes pinger {
    0% {
        transform: scale(0);
    }

    50% {
        transform: scale(2);
    }

    100% {
        transform: scale(0);
    }
}

.r_websocketserverping {
    position: fixed;
    left: 10px;
    bottom: 10px;
    background-color: var(--gfpal-yellow);
    width: 10px;
    height: 10px;
    transform: scale(0);
    border-radius: 50%;
}

    .r_websocketserverping.active {
        animation: pinger 1s forwards;
    }


.g_gs1details {
    font-size: 12pt;
    text-align: left;
}

    .g_gs1details .prop {
        display: flex;
        margin: 0 0 4px 0;
    }

        .g_gs1details .prop .name {
            width: 240px;
            font-weight: bold;
        }

.g_extratag {
    display: flex;
    align-items: center;
    justify-content: center;
    gap:10px;
}

    .g_extratag .tag {
        background-color: #ececec;
        box-sizing: border-box;
        padding: 2px 8px;
        border-radius: 3px;
        font-size: 9pt;
        text-align: center;
    }

    .g_extratag.flexalignstart {
        justify-content: flex-start;
        margin: 4px 0;
    }

.r_globalnotification {
    position: fixed;
    top: 15px;
    width: 50%;
    left: 25%;
    color: var(--gfpal-yellow);
    font-size: 12pt;
    text-align: center;
    cursor: pointer;
}

    .r_globalnotification i,
    .sc_globalnotification i {
        padding-right: 2px;
    }

.r_notificationoverview {
    margin: 40px;
    background-color: white;
    padding: 30px 60px 60px 60px;
}

.sc_globalnotification {
    width: 100%;
    background-color: var(--gfpal-BG1);
    color: var(--gfpal-yellow);
    font-size: 12pt;
    text-align: center;
    cursor: pointer;
    padding: 0 0 10px 0;
}

.sc_globalnotificationdetail {
    background-color: var(--gfpal-BG1);
    color: var(--gfpal-yellow);
    box-sizing: border-box;
    padding: 20px;
    display: none;
}

    .sc_globalnotificationdetail > p {
        margin-top: 0;
    }

.flex {
    display: flex;
}

.shipped_animationcontainer,
.shipfailed_container {
    z-index: 9999;
}

.g_spinner {
    display: flex;
    opacity:0.2;
}

    .g_spinner.active {
        opacity: 1;
    }

    .g_spinner .button {
        width: 30px;
        height: 30px;
        display: flex;
        justify-content: center;
        align-items: center;
        color: white;
        border-radius: 50%;
        font-weight: bold;
        cursor: pointer;
    }

        .g_spinner .button.plus {
            background-color: var(--gfpal-bluevibrant);
        }

        .g_spinner .button.minus {
            background-color: black;
        }

    .g_spinner .value {
        width: 30px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

.g_centered_message {
    width:100%;
    height: 80vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.g_extratag {
    gap: 10px
}

.hidden {
    display: none !important;
}