body.login-page.register-page .login-card {
    background: var(--color-secondary);
}

.register-divider {
    height: 1px;
    background: rgba(0,0,0,.08);
    margin: 8px 0;
}

.register-subtitle {
    opacity: .75;
    font-size: .95rem;
    margin: 4px 0 6px;
}

.register-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.number-addition {
    max-width: 124.3px;
}

/* --- Password fields --- */
.pw-field {
    position: relative;
    width: 100%;
}

    /* input blijft full width, maar krijgt ruimte voor het oogje IN de balk */
    .pw-field .login-input {
        width: 100%;
        box-sizing: border-box;
        padding-right: 48px; /* ruimte voor het oogje */
    }

/* oogje "in" de input */
.pw-toggle {
    position: absolute;
    right: 10px;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: .9; /* iets hoger zodat ie lichter zichtbaar is */
}

    .pw-toggle:hover {
        opacity: 1;
    }

    /* lucide icon zelf wat subtieler en consistent */
    .pw-toggle svg {
        width: 18px;
        height: 18px;
        opacity: .75;
    }

/* rules (jouw JS zet 'm boven het eerste veld, dus margin normaal) */
.pw-rules {
    margin: 0 0 8px 0;
    font-size: 12px;
    line-height: 1.4;
    color: #64748B;
}

@media (max-width: 640px) {
    .register-row {
        grid-template-columns: 1fr;
    }

    .number-addition {
        max-width: none;
    }

    body.login-page.register-page #app {
        padding: 12px;
    }

    body.login-page.register-page .login-card {
        max-width: none;
        width: 100%;
        border-radius: 10px;
    }
}

