/* Password field with visibility toggle — portal & admin */

.password-input-group,
.premium-input-group.password-field-group {
    display: flex;
    align-items: stretch;
    width: 100%;
    position: relative;
}

.password-input-group {
    border: 1px solid #e6dfd7;
    border-radius: 0.375rem;
    background: #fff;
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.password-input-group:focus-within {
    border-color: #165438;
    box-shadow: 0 0 0 0.2rem rgba(22, 84, 56, 0.15);
}

.password-input-group .password-field-input {
    flex: 1 1 auto;
    min-width: 0;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.password-input-group .password-field-input:focus {
    box-shadow: none !important;
}

.premium-input-group.password-field-group {
    overflow: hidden;
}

.premium-input-group.password-field-group .password-field-input {
    flex: 1 1 auto;
    min-width: 0;
}

.password-toggle-btn {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    min-width: 2.75rem;
    padding: 0;
    margin: 0;
    border: none;
    background: transparent;
    color: #165438;
    cursor: pointer;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.password-toggle-btn:hover {
    color: #c85a32;
    background: rgba(22, 84, 56, 0.06);
}

.password-toggle-btn:focus-visible {
    outline: 2px solid #165438;
    outline-offset: -2px;
}

.premium-input-group .password-toggle-btn {
    color: #2c5545;
    border-left: 1px solid #e9ecef;
}

.premium-input-group .password-toggle-btn:hover {
    background: rgba(44, 85, 69, 0.08);
}

.password-toggle-btn .bi {
    font-size: 1.15rem;
    pointer-events: none;
}
