body{
    background: #3D454D;
    margin: 0;
}

.l {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    justify-content: space-between;
}

.l-header {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 20px;
    padding: 40px 80px;
    color: var(--neutrals-50);
}

.lm {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    flex: 1;
    padding: 20px 20px 0px;
}

/* Background */
.background-image {
    position: absolute;
    left: 0%;
    /* top: 65px; */
    min-width: 100%;
    height: 653px;
    z-index: -1;
    background: url("../images/twig.4799f5268b95.png");
    background-size: cover;
}

.background-gradient {
    position: absolute;
    width: 100%;
    height: 297px;
    left: 0px;
    top: 361px;
    z-index: -1;

    background: linear-gradient(180deg, rgba(98, 106, 115, 0) 0%, #3D454D 100%);
}

/* Topbar */
.topbar {
    position: relative;
    width: 100%;
    height: 70px;
    background-color: var(--lemonyellow-400);
    color: var(--metalgray-800);
    display: flex;
    box-sizing: border-box;
}

.topbar-text {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    padding: 20px;
}

.topbar-login-button {
    display: none;
    gap: 8px;
}

/* Header */
.header {
    position: relative;
    margin: 96px 0px 18px;
    color: white;
}


.login-main {
    position: relative;
    display: flex;
    gap: 24px;
    align-content: stretch;
}

/* Info Cards */
.info-card {
    display: flex;
    padding: 32px;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
    flex: 1 0 0;
    align-self: stretch;

    color: var(--metalgray-600);

    grid-column: span 4;

    border-radius: 8px;
    border: 1px solid var(--idmSemColorContainerCanvas);
    background: var(--neutrals-50);
    box-shadow: var(--boxshadow-bottom);
    box-sizing: border-box;
}


.info-card-main {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 20px;

    width: 100%;
}

.info-card-main-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 12px;

    width: 100%;
}

.info-card-main-contact {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;

    width: 100%;
}



.info-card-main-contact-kind {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0px;
    gap: 8px;
}


.info-card-bottom {
    box-sizing: border-box;

    display: flex;
    flex-direction: row;
    align-items: flex-start;
    color: var(--metalgray-400);
}

.login {
    flex-grow: 1;
    display: flex;
    justify-content: right;
    align-items: flex-start;
    color: var(--metalgray-800);
    grid-column-start: 9;
    grid-column-end: 13;
    grid-row-start: 2;
    grid-row-end: 4;
    align-items: center;
}

.login-modal {
    width: 830px;
}

.login-modal .modal-logo-group {
    justify-content: center;
}

.login-modal .input-area{
    width: 100%;
}

.login-modal .modal-stack,
.login-modal .card-inner {
    align-items: center;
}

.login-action {
    align-items: flex-end;
}

.login-action .modal-stack{
    width: 50%;
}



.login-card {
    box-sizing: border-box;

    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 40px;
    gap: 32px;

    width: 396px;

    background: var(--neutrals-50);

    border: 1px solid var(--idmSemColorContainerCanvas);

    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.05);
    border-radius: 8px;
}

.login-card-header {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0px;
    gap: 24px;

    flex-wrap: wrap;
}

.login-card-header-logo {
    height: 72px;
    width: 72px;
}

.login-card-input {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 16px;

    width: 100%;
}

.login-card-input-password {
    position: relative;
    width: 100%;
}

.passwordInput {
    padding-right: 60px;
}

.password-icon {
    position: absolute;
    right: 20px;
    top: 12px;
}

.password-icon:hover {
    cursor: pointer;
}

.login-card-submit {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 24px;
}


.login-card-input-div {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 16px;

    width: 100%;
}

.login-card-submit {
    width: 100%;
    position: relative;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.login-card-submit-div {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0px;
    gap: 4px;
}

.site-info {
    display: flex;
    gap: 16px;
    margin-bottom: 32px;
    align-items: flex-end;
    color: var(--metalgray-400);
}

.site-info-right {
    display: flex;
    gap: 16px;
    flex-direction: row;
}

.login-fullscreen {
    position: fixed;
    height: 100vh !important;
    width: 100vw !important;
    top: 50px;
    border-radius: 0px;
}

.input-field-area input[type="radio"] {
    width: calc(var(--idmCompRadiobuttonSizeMd));
}

@media screen and (max-width: 1900px) {
    .info-card-lg {max-height: unset;}
    .info-card-sm {max-height: unset;}
}

@media screen and (max-width: 1114px) {
    .header {
        margin: 90px 0px 8px;
    }
}

@media screen and (max-width: 957px) {
    .login-main {
        flex-wrap: wrap;
        order: 1;
        gap: 80px;
    }
    .info {
        order: 2;
    }
}

@media screen and (max-width: 768px) {
    .topbar {
        height: 50px;
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .topbar-text {
        display: flex;
        padding: 0px 20px;
        justify-content: space-between;
        width: 100%;
    }

    .background-image {
        height: 330px;
        background-image: url("../images/twig-mobile.354714c25e8f.png");
    }

    .background-gradient {
        top: 166px;
        height: 214px;
    }


    .login {
        grid-column: span 12!important;
    }

    .login-card {
        width: 100%;
        height: auto;
        padding: 32px 24px;
        gap: 24px
    }

    .login-modal {
        width: 100%;
        height: auto;
    }

    .info-card {
        display: none;
    }

    .login-main {
        gap: 0px;
    }

    .password-icon {
        top: 14px;
    }

    .site-info {
        margin: 20px;
        justify-content: space-between;
    }

    .topbar-login-button {
        display: flex;
        align-items: center;
    }
}

@media screen and (max-width: 490px) {
    .site-info {
        flex-wrap: wrap;
    }
}
