﻿:root {
    --theme-color: #186923;
    --sign-bar-width: 85%;
    --sign-bar-border: 0.015rem;
    --sign-bar-border-radius: 1.0rem;
    --sign-bar-spacing: 0.5rem;
    --sign-bar-shadow-color: rgba(0, 0, 0, 0.15);
    --sign-bar-shadow: 1px 1px 2px 0 var(--sign-bar-shadow-color);
    --sign-bar-fontSize: 0.85rem;
    --sign-bar-iconSize: 1.15rem;
    --sign-bar-lineHeight: 0.9rem;
    --sign-bar-bullet-height: 1.25rem;
    --sign-bar-bullet-width: 1.0rem;
}

html {
    height: 100vh;
}

body {
    background-color: #f8f8f8;
    overflow: hidden;
}

.gradient-custom-2 {
    /* fallback for old browsers */
    background: #fccb90;
    /* Chrome 10-25, Safari 5.1-6 */
    background: -webkit-linear-gradient(to right, #ee7724, #d8363a, #dd3675, #b44593);
    /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
    background: linear-gradient(to right, #ee7724, #d8363a, #dd3675, #b44593);
}

@media (min-width: 768px) {
    .gradient-form {
        height: 100vh !important;
    }
}

@media (min-width: 769px) {
    .gradient-custom-2 {
        border-top-right-radius: .3rem;
        border-bottom-right-radius: .3rem;
    }
}

.sign-in-out {
    position: relative;
    display: inline-block;
    background-color: #ffffff;
    background-image: url(images/line-bgr.png);
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    border: solid var(--sign-bar-border) #dedede;
    border-radius: 0.25rem;
    overflow: hidden;
    width: calc(100% - 0.5rem);
    min-width: 260px;
    max-width: 24rem;
    margin: 0 0.25rem 2rem 0.25rem;
    padding: 0;
    font-size: var(--sign-bar-fontSize);
    font-weight: normal;
    text-transform: none;
    text-align: center;
    -moz-box-shadow: 3px 3px 5px 0 var(--sign-bar-shadow-color);
    -webkit-box-shadow: 3px 3px 5px 0 var(--sign-bar-shadow-color);
    box-shadow: 3px 3px 5px 0 var(--sign-bar-shadow-color);
}

    .sign-in-out a {
        text-decoration: none;
    }

    .sign-in-out .dropdown-item {
        font-size: calc(var(--sign-bar-fontSize) - 0.1rem) !important;
    }

    .sign-in-out .sign-top-bar {
        position: absolute;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        top: 0;
        left: 0;
        padding: 0.25rem 0.75rem;
        overflow: visible;
        background: none;
    }

    .sign-in-out .sign-logo {
        position: relative;
        display: flex;
        flex-direction: row;
        justify-self: center;
        align-items: center;
        text-align: center;
        height: 12rem;
        width: 12rem;
        margin: 1.0rem 0 2rem 0;
        padding: 0.35rem;
        overflow: hidden;
    }

        .sign-in-out .sign-logo img {
            max-height: 100%;
            max-width: 100%;
            object-fit: contain;
        }

    .sign-in-out .sign-options {
        position: relative;
        display: inline-block;
        width: 100%;
        padding: 1.0rem;
        margin: 1.0rem 0 2.0rem 0;
    }

        .sign-in-out .sign-options button {
            position: relative;
            display: inline-block;
            padding-left: 1.25rem;
            padding-right: 1.25rem;
            font-size: var(--sign-bar-fontSize);
            line-height: 1.0rem;
        }

    .sign-in-out .sign-copyright {
        position: absolute;
        display: block;
        bottom: 0;
        right: 0.5rem;
        font-size: 0.6rem;
        font-weight: normal;
        font-style: italic;
        color: #cdcdcd;
    }

.sign-bar-left,
.sign-bar-right {
    position: relative;
    display: inline-block;
    width: var(--sign-bar-width);
    height: fit-content;
    padding: 0;
    margin: 0;
    margin-top: var(--sign-bar-spacing);
    margin-left: calc(var(--sign-bar-width) - 100%);
    color: #777 !important;
    background-color: white;
    border: solid var(--sign-bar-border) #dedede;
    border-left: none;
    border-radius: 0 var(--sign-bar-border-radius) var(--sign-bar-border-radius) 0;
    -moz-box-shadow: var(--sign-bar-shadow);
    -webkit-box-shadow: var(--sign-bar-shadow);
    box-shadow: var(--sign-bar-shadow);
}

.sign-bar-right {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: calc(var(--sign-bar-width) - 100%);
    border-right: none;
    border-radius: var(--sign-bar-border-radius) 0 0 var(--sign-bar-border-radius);
    -moz-box-shadow: var(--sign-bar-shadow);
    -webkit-box-shadow: var(--sign-bar-shadow);
    box-shadow: var(--sign-bar-shadow);
}

    .sign-bar-left:focus,
    .sign-bar-left:hover,
    .sign-bar-left:active,
    .sign-bar-right:focus,
    .sign-bar-right:hover,
    .sign-bar-right:active {
        background: #ffffeb;
    }

    .sign-bar-left .form-floating,
    .sign-bar-right .form-floating {
        overflow: hidden;
        padding: 0 !important;
        height: calc(3.75 * var(--sign-bar-lineHeight)) !important;
    }

        .sign-bar-left .form-floating,
        .sign-bar-left .form-floating .form-control {
            border-radius: 0 var(--sign-bar-border-radius) var(--sign-bar-border-radius) 0 !important;
        }

        .sign-bar-right .form-floating,
        .sign-bar-right .form-floating .form-control {
            border-radius: var(--sign-bar-border-radius) 0 0 var(--sign-bar-border-radius) !important;
        }

    .sign-bar-left span.input-group-text,
    .sign-bar-right span.input-group-text {
        background: none !important;
        border: none !important;
        border-radius: 0 !important;
        padding: 0 !important;
        color: unset !important;
        -webkit-user-select: none;
        -ms-user-select: none;
        user-select: none;
    }

        .sign-bar-left span.input-group-text > i,
        .sign-bar-right span.input-group-text > i {
            font-size: var(--sign-bar-iconSize) !important;
            margin: 0 0.5rem 0 1.0rem !important;
        }

    .sign-bar-left .input-group-text:has(~.form-floating>.form-control-plaintext),
    .sign-bar-left .input-group-text:has(~.form-floating>.form-control:focus),
    .sign-bar-left .input-group-text:has(~.form-floating>.form-select),
    .sign-bar-left .input-group-text:has(~.form-floating>.form-control:not(:placeholder-shown)),
    .sign-bar-right .input-group-text:has(~.form-floating>.form-control-plaintext),
    .sign-bar-right .input-group-text:has(~.form-floating>.form-control:focus),
    .sign-bar-right .input-group-text:has(~.form-floating>.form-select),
    .sign-bar-right .input-group-text:has(~.form-floating>.form-control:not(:placeholder-shown)) {
        color: var(--theme-color) !important;
    }

    .sign-bar-left .form-floating *,
    .sign-bar-left .form-floating *::after,
    .sign-bar-right .form-floating *,
    .sign-bar-right .form-floating *::after {
        border: none !important;
        outline: none !important;
        background: none !important;
        -webkit-box-shadow: none !important;
        box-shadow: none !important;
    }

.sign-in-out .sign-text-error {
    font-size: calc(0.85 * var(--sign-bar-fontSize));
    width: 100% !important;
    text-align: left;
    font-style: italic;
    margin: 0;
    padding: 0 0 0 var(--sign-bar-fontSize);
    color: red;
}

    .sign-in-out .sign-text-error + .sign-bar-left,
    .sign-in-out .sign-text-error + .sign-bar-right {
        margin-top: 0 !important;
    }

.sign-in-out .sign-bar-left + .sign-text-error,
.sign-in-out .sign-bar-right + .sign-text-error {
    margin-top: var(--sign-bar-spacing) !important;
}

.dropdown-menu:has(> .reg-id-type) {
    padding: 1.0rem 0.25rem 0.25rem 0.25rem;
    width: auto;
}

.reg-id-type {
    padding: 0 0.35rem !important;
    margin: 0 !important;
    line-height: 2.0rem;
    position: relative;
    width: 100%;
}

    .reg-id-type a {
        padding: 0 0.75rem 0 calc(var(--sign-bar-bullet-width) + 0.5rem);
        border: solid var(--sign-bar-border) #4eb543;
        width: 100%;
        height: 100%;
        text-transform: uppercase;
        font-weight: bold;
        color: #777 !important;
        background: none !important;
    }

    .reg-id-type:hover a {
        background: #f0fff2 !important;
    }

    .reg-id-type a:active {
        color: #555 !important;
        background: none !important;
    }

    .reg-id-type a::before {
        content: '';
        position: absolute;
        display: inline-block;
        background: none;
        left: 0;
        top: 50%;
        height: calc(2 * var(--sign-bar-bullet-height));
        width: var(--sign-bar-bullet-width);
        border-top: var(--sign-bar-bullet-height) solid transparent;
        border-bottom: var(--sign-bar-bullet-height) solid transparent;
        border-left: var(--sign-bar-bullet-width) solid #4eb543;
        border-right: 0;
        transform: translateY(-50%);
    }

.wellcome-panel {
    background: white;
    border-radius: 0.2rem;
    border: solid thin #098500;
}

.welcome-logo {
    background: none;
    text-align: center;
    padding: 1.5rem 0;
}

    .welcome-logo img {
        width: 100%;
        height: auto;
        max-height: 100%;
        max-width: 10rem;
        object-fit: contain;
    }

.welcome-content {
    display: inline-block;
    position: relative;
    margin: 0;
}

    .welcome-content::before {
        content: ' ';
        display: none;
        position: absolute;
        height: 65%;
        width: 0.1rem;
        top: 50%;
        left: 0;
        margin: 0;
        padding: 0;
        background-color: #00a015;
        transform: translateY(-50%);
    }

@media (min-width: 768px) {
    .welcome-content::before {
        display: block;
    }
}

.welcome-bg-animation {
    animation: slide 3s ease-in-out infinite alternate;
    background-image: linear-gradient(-60deg, #fff 0%, #c8edc4 25%, #fff 50%, #fff7c0 75%, #fff 100%);
    bottom: 0;
    left: -50%;
    opacity: 1.0;
    position: fixed;
    right: -50%;
    top: 0;
    z-index: -1;
}

.welcome-bg-animation2 {
    animation-direction: alternate-reverse;
    animation-duration: 5s;
}

.welcome-bg-animation3 {
    animation-duration: 7s;
}

@keyframes slide {
    0% {
        transform: translateX(-25%);
    }

    100% {
        transform: translateX(25%);
    }
}
