/* PMS Login / Logout / Password Reset */

/* Center standalone auth forms/messages in the available viewport area */
main.site-main:has(#pms_login) .entry-content,
main.site-main:has(#pms_recover_password_form) .entry-content,
main.site-main:has(#pms_new_password_form) .entry-content,
main.site-main:has(.pms_success-messages-wrapper) .entry-content,
main.site-main:has(.pms-password-reset-success) .entry-content,
main.site-main:has(.pms-front-end-logout) .entry-content,
main.site-main:has(p.pms-alert) .entry-content {
    min-height: calc(100dvh - 240px);
    display: grid;
    align-content: center;
    justify-items: center;
    row-gap: 18px;
    padding: 24px 0;
    box-sizing: border-box;
    width: 100%;
}

main.site-main:has(#pms_login) #pms_login {
    margin: 0;
}

main.site-main:has(#pms_login) p.pms-login-error {
    margin: 0 !important;
}

main.site-main:has(#pms_recover_password_form) #pms_recover_password_form,
main.site-main:has(#pms_new_password_form) #pms_new_password_form {
    margin: 0;
}

main.site-main:has(.pms-front-end-logout) .pms-front-end-logout {
    margin: 0 !important;
}

main.site-main:has(.pms_success-messages-wrapper) .pms_success-messages-wrapper,
main.site-main:has(.pms-password-reset-success) .pms-password-reset-success,
main.site-main:has(p.pms-alert) p.pms-alert {
    margin: 0 !important;
}

/* PMS login */
#pms_login {
    width: 100%;
    max-width: 482px !important;
    margin: 0 auto;
    padding: 36px 40px;
    background: var(--theme-palette-color-8, #f9f9f9);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: 180px 188px;
    justify-content: center;
    column-gap: 32px;
    row-gap: 18px;
}

#pms_login p {
    margin: 0;
}

#pms_login .login-username,
#pms_login .login-password,
#pms_login .login-remember {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    gap: 0px;
}

#pms_login label {
    font-weight: 500;
    color: var(--theme-palette-color-3, #222);
}

#pms_login .input {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--theme-palette-color-6, #dfe3e6);
    border-radius: 6px;
    box-sizing: border-box;
    background: #fbfbfb;
    font-size: 15px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#pms_login .pp-password-field {
    position: relative;
    width: 100%;
}

#pms_login .pp-password-field input {
    padding-right: 44px;
}

#pms_login .pp-password-toggle {
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 0;
    padding: 0;
    background: none;
    color: var(--grey-4, #666);
    cursor: pointer;
}

#pms_login .pp-password-toggle:focus {
    outline: none;
    box-shadow: 0 0 0 2px rgba(10, 108, 136, 0.2);
    border-radius: 4px;
}

#pms_login .pp-password-toggle .pp-icon {
    width: 18px;
    height: 18px;
}

#pms_login .pp-password-field .pp-icon-eye-off {
    display: none;
}

#pms_login .pp-password-field.is-visible .pp-icon-eye {
    display: none;
}

#pms_login .pp-password-field.is-visible .pp-icon-eye-off {
    display: block;
}

#pms_login .input:focus {
    border-color: var(--theme-palette-color-5, #0a6d8e);
    box-shadow: 0 0 0 2px rgba(10, 109, 142, 0.15);
    outline: none;
}

#pms_login .login-remember {
    flex-direction: row;
    align-items: center;
    gap: 8px;
}

#pms_login .login-remember label {
    font-weight: 400;
}

#pms_login input[type="checkbox"] {
    accent-color: var(--theme-palette-color-5, #006d91);
}

#pms_login .login-submit {
    grid-column: 1 / 2;
    align-self: start;
}

#pms_login .login-extra {
    grid-column: 2 / 3;
    align-self: center;
    justify-self: end;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    font-size: 0.95rem;
}

#pms_login .button-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 180px;
    padding: 13px 18px;
    background: var(--theme-palette-color-5, #006d91);
    color: var(--theme-palette-color-8, #f4f4f4);
    border: none;
    border-radius: 6px;
    font-size: 17px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.08s ease, box-shadow 0.12s ease, background-color 0.12s ease;
}

#pms_login .button-primary:hover {
    background: var(--theme-palette-color-5, #006d91);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

#pms_login .login-extra a {
    color: var(--theme-palette-color-5, #006d91);
    text-decoration: none;
    font-weight: 400;
}

#pms_login .login-extra a:hover {
    text-decoration: underline;
}

#pms_login .login-extra .separator {
    color: var(--theme-palette-color-5, #006d91);
}

/* ============================
Password reset form 
==============================*/
#pms_recover_password_form {
    max-width: 500px;
    margin: 72px auto;
    padding: 32px 32px 28px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

#pms_recover_password_form > p {
    margin: 0;
    font-size: 1.0rem;
    color: var(--theme-palette-color-3, #222);
    line-height: 1.5;
}

#pms_recover_password_form .pms-form-fields-wrapper {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

#pms_recover_password_form .pms-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#pms_recover_password_form label {
    font-weight: 600;
    color: var(--theme-palette-color-3, #222);
}

#pms_recover_password_form input[type="text"] {
    width: 100%;
    padding: 13px 14px;
    border: 1px solid var(--theme-palette-color-6, #dfe3e6);
    border-radius: 6px;
    font-size: 15px;
    background: #fbfbfb;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#pms_recover_password_form input[type="text"]:focus {
    border-color: var(--theme-palette-color-5, #0a6d8e);
    box-shadow: 0 0 0 2px rgba(10, 109, 142, 0.15);
    outline: none;
}

#pms_recover_password_form input[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 200px;
    padding: 13px 18px;
    background: var(--theme-palette-color-5, #006d91);
    color: var(--theme-palette-color-8, #f4f4f4);
    border: none;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.08s ease, box-shadow 0.12s ease, background-color 0.12s ease;
}

#pms_recover_password_form input[type="submit"]:hover {
    background: var(--theme-palette-color-5, #006d91);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

#pms_recover_password_form input[type="submit"]:active {
    transform: translateY(0);
    box-shadow: none;
}

/*===============
New password form (when resetting password, reset link)
======================*/

#pms_new_password_form{
    max-width: 500px;
    margin: 72px auto;
    padding: 32px 32px 28px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 8px !important;
}

#pms_new_password_form .pms-form-fields-wrapper{
    list-style: none;
    margin-bottom: 18px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

#pms_new_password_form .pms-field{
    display: grid;
    grid-template-columns: 1fr 170px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

#pms_new_password_form .pms-field p{
    margin: 0;
    font-size: 0.88rem;
    color: #444;
    line-height: 1.3;
}

#pms_new_password_form label{
    font-weight: 600;
    color: var(--theme-palette-color-3, #222);
}

#pms_new_password_form input[type="password"]{
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--theme-palette-color-6, #dfe3e6);
    border-radius: 6px;
    font-size: 15px;
    background: #fbfbfb;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#pms_new_password_form input[type="password"]:focus{
    border-color: var(--theme-palette-color-5, #0a6d8e);
    box-shadow: 0 0 0 2px rgba(10, 109, 142, 0.15);
    outline: none;
}

#pms-pass-strength-result{
    display: inline-flex;
    align-items: center;
    font-size: 0.9rem;
    margin: 0;
    padding: 8px 12px;
    width: auto;
    white-space: nowrap;
    text-align: center;
    border: 1px solid var(--theme-palette-color-6, #dfe3e6);
    border-radius: 6px;
}

#pms_new_password_form input[type="submit"]{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 220px;
    padding: 13px 18px;
    background: var(--theme-palette-color-5, #006d91);
    color: var(--theme-palette-color-8, #f4f4f4);
    border: none;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.08s ease, box-shadow 0.12s ease, background-color 0.12s ease;
}

#pms_new_password_form input[type="submit"]:hover{
    background: var(--theme-palette-color-5, #006d91);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

#pms_new_password_form input[type="submit"]:active{
    transform: translateY(0);
    box-shadow: none;
}


/*===============
Message wrappers
======================*/

.pms_success-messages-wrapper{
    max-width: 500px;
    margin: 144px auto !important;
    padding: 16px 24px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    text-align: center;
}

.pms_success-messages-wrapper p{
    background-color: transparent !important;
    padding:0;
    margin:0;
    border:none !important;
    font-size: 1rem;
    color: var(--theme-palette-color-3, #222) !important;
}

.pms-password-reset-success{
    max-width: 500px;
    margin: 144px auto !important;
    padding: 16px 24px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    text-align: center;
}

.pms-password-reset-success p{
    background-color: transparent !important;
    padding:0;
    margin:0;
    border:none !important;
    font-size: 1rem;
    color: var(--theme-palette-color-3, #222) !important;
}

p.pms-login-error{
    max-width: 500px;
    margin: 36px auto !important;
    padding: 16px 24px;
    background: var(--lavender-tint, #f4f3ff);
    border: 1px solid var(--theme-palette-color-6, #DAEAED);
    border-radius: 6px;
    font-size: 0.95rem;
    color: var(--pp-red-3, #d23d33);
    text-align: center;
}

p.pms-alert{
    max-width: 500px;
    margin: 144px auto !important;
    padding: 16px 24px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    text-align: center;
    font-size: 1rem;
    color: var(--theme-palette-color-3, #222) !important;
}


/* Responsive: phones */
@media (max-width: 768px) {
    main.site-main:has(#pms_login) .entry-content,
    main.site-main:has(#pms_recover_password_form) .entry-content,
    main.site-main:has(#pms_new_password_form) .entry-content,
    main.site-main:has(.pms_success-messages-wrapper) .entry-content,
    main.site-main:has(.pms-password-reset-success) .entry-content,
    main.site-main:has(.pms-front-end-logout) .entry-content,
    main.site-main:has(p.pms-alert) .entry-content {
        display: grid;
        align-content: start;
        justify-items: center;
        row-gap: 16px;
        padding: 20px 0;
    }

    main.site-main:has(#pms_login) #pms_login {
        margin: 0;
    }

    #pms_login {
        grid-template-columns: 1fr;
        row-gap: 16px;
        column-gap: 0;
        padding: 28px 22px;
        margin: 0;
    }

    #pms_login .login-username,
    #pms_login .login-password,
    #pms_login .login-remember,
    #pms_login .login-submit,
    #pms_login .login-extra {
        grid-column: 1 / -1;
    }

    #pms_login .login-extra {
        justify-self: start;
    }

    #pms_recover_password_form {
        margin: 48px auto;
        padding: 24px 22px;
    }

    #pms_new_password_form{
        margin: 48px auto;
        padding: 24px 22px;
    }

    #pms_new_password_form .pms-field{
        grid-template-columns: 1fr;
    }

    #pms_new_password_form .pms-field p,
    #pms-pass-strength-result{
        grid-column: 1 / -1;
    }
}


.pms-front-end-logout{
    max-width: 500px;
    margin: 144px auto !important;
    padding: 16px 24px;
    background: var(--theme-palette-color-8, #f4f4f4);
    border: 1px solid var(--theme-palette-color-6, #c6f2ff);
    border-radius: 8px;
    font-size: 1rem;
    text-align: center;

}
