﻿/* Login page ---------------------------------------------------------------------------------- */
.login-bg {
    background-image: linear-gradient(to bottom, transparent 0 60%, var(--apc-color__blue-dark-main) 100%), url("/img/bg/bg-square_1080x1080px.jpg"), linear-gradient(to bottom, var(--apc-color__blue-dark-main), var(--apc-color__blue-dark-main));
    background-repeat: no-repeat;
    background-size: 100vw auto;
    background-position: top center;
}

@media (orientation: portrait) {
    .login-bg {
        background-image: linear-gradient(to bottom, transparent 0 60%, var(--apc-color__blue-dark-main) 100%), url("/img/bg/bg-portrait_1080x1920px.jpg"), linear-gradient(to bottom, var(--apc-color__blue-dark-main), var(--apc-color__blue-dark-main));
    }
}

@media (orientation: portrait) and (max-width: 350px) {
    .login-bg {
        background-size: cover;
    }
}

.main-content {
    display: flex;
    flex: 1 0 auto;
    flex-flow: column nowrap;
    justify-content: flex-start;
}

@media (min-width: 768px) {
    .main-content {
        min-height: 30vw;
    }
}

.login-body {
    flex-grow: 1;
    display: flex;
    flex-flow: column;
    gap: var(--rem__larger);
}

@media (min-width: 768px) {
    .login-body {
        gap: calc(var(--rem__larger) * var(--size__large));
    }
}

.login-content {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
        "login-text"
        "login-form";
    gap: var(--rem__larger);
    margin-inline: var(--rem__larger);
    border-radius: var(--apc-border-radius__normal);
}

@media (min-width: 768px) {
    .login-content {
        grid-template-columns: repeat(12, 1fr);
        grid-template-areas:
            "hole1 login-text login-text login-text login-text hole2 login-form login-form login-form login-form login-form hole3";
        gap: calc(var(--rem__larger) * var(--rem__normal));
        margin-inline: auto;
    }
}

.apc-choice-logo {
    grid-area: login-title;
    display: flex;
    flex-flow: column nowrap;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
    margin-top: var(--rem__normal);
}

    .apc-choice-logo img {
        width: 100%;
    }

@media (min-width: 768px) {
    .apc-choice-logo img {
        width: 100%;
    }
}

.login-text {
    grid-area: login-text;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: var(--rem__normal);
    font-size: var(--apc-font-size__large);
    color: var(--apc-color__white);
}

    .login-text p {
        margin-bottom: 0;
    }

.apc-choice-logo-as-text {
    font-size: 48px;
    font-weight: var(--apc-font-weight__medium);
    line-height: 1;
    color: var(--apc-color__white);
}

@media (min-width: 768px) {
    .apc-choice-logo-as-text {
        font-size: 5vw;
        margin-bottom: 40px;
    }
}

.login-form {
    grid-area: login-form;
    display: block;
    padding-block: var(--rem__large);
    padding-inline: var(--rem__larger);
    background-color: rgb(255 255 255 / 80%);
    border-radius: var(--apc-border-radius__normal);
}

    .login-form > form {
        width: 100%;
    }

@media (min-width: 768px) {
    .login-form {
        margin-top: 0;
    }
}

.field-container {
    display: flex;
    flex-flow: column nowrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: var(--rem__normal);
    margin-top: var(--rem__large);
}

@media (min-width: 768px) {
    .field-container {
        flex-flow: row wrap;
        justify-content: flex-start;
        align-items: flex-end;
    }
}

.field-group {
    flex-basis: auto;
    display: block;
    font-size: var(--apc-font-size__normal);
    width: 100%;
}

    .field-group label {
        display: block;
        margin-bottom: var(--rem__smaller);
        font-size: var(--rem__normal);
        font-weight: var(--apc-font-weight__medium);
        color: var(--apc-color__blue-dark-main);
        white-space: nowrap;
    }

    .field-group input[type="text"] {
        font-size: var(--apc-font-size__normal);
    }

@media (min-width: 768px) {
    .field-group {
        flex-basis: 0;
        width: auto;
    }
}

#ConsignmentNumber {
    min-width: 175px;
}

.login-error-container {
    display: block;
    margin-block: var(--rem__small);
}

    .login-error-container .login-error {
        margin-bottom: var(--rem__smaller);
        color: var(--apc-color__red);
        font-weight: var(--apc-font-weight__medium);
    }

        .login-error-container .login-error:first-child {
            border-top-left-radius: var(--apc-border-radius__normal);
            border-top-right-radius: var(--apc-border-radius__normal);
        }

        .login-error-container .login-error:last-child {
            margin-bottom: 0;
            border-bottom-left-radius: var(--apc-border-radius__normal);
            border-bottom-right-radius: var(--apc-border-radius__normal);
        }

.login-faqs {
    flex-grow: 1;
    grid-area: login-faqs;
    display: flex;
    flex-flow: column nowrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: var(--rem__large);
    padding-block: calc(var(--rem__large) * 2);
    padding-inline: var(--g12-col1);
    background-color: var(--apc-color__white);
    font-size: var(--apc-font-size__normal);
}

    .login-faqs h1 {
        text-transform: none;
    }

    .login-faqs p:last-child {
        margin-bottom: 0;
    }

    .login-faqs .faq:last-child {
        padding-bottom: 0;
    }

.faq {
    width: 100%;
    padding-bottom: var(--rem__large);
    border-bottom: 1px dotted var(--apc-color__grey-800);
}

    .faq:last-child {
        border-bottom: none;
    }

    .faq h2 {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: flex-end;
        gap: var(--rem__large);
        margin: 0;
        text-transform: none;
        color: var(--apc-color__black);
    }

        .faq h2 .faq-title {
            flex: 1 1 0;
        }

        .faq h2 .icon {
            flex: 0 0 auto;
            display: inline-block;
            background-image: url("/img/plus.svg");
            background-repeat: no-repeat;
            background-size: contain;
            height: var(--rem__normal);
            width: var(--rem__normal);
            transform: rotate(0deg);
            transition: transform ease-in-out 0.2s;
        }

    .faq p, .faq ul {
        display: none;
        margin-right: var(--rem__larger);
    }

    .faq.active p, .faq.active ul {
        display: block;
    }

    .faq.active h2 > .icon {
        transform: rotate(45deg);
    }

.hole1 {
    grid-area: hole1;
    background-color: transparent;
}

.hole2 {
    grid-area: hole2;
    background-color: transparent;
}

.hole3 {
    grid-area: hole3;
    background-color: transparent;
}

.grow-0 {
    flex-grow: 0;
}

.grow-1 {
    flex-grow: 1;
}

.shrink-0 {
    flex-shrink: 0;
}

.shrink-1 {
    flex-shrink: 1;
}

.fixed-size {
    flex: 0 0 auto;
}
