/* Password eye — กดค้างเพื่อดูรหัสผ่าน ปล่อย=ซ่อน
   Auto-attach โดย /js/password-eye.js ทุก input[type=password]
   - opt-out: ใส่ data-pw-eye-skip="true" ที่ input
   - หรือถ้า input อยู่ใน element ที่มี class .pw-wrap / .pwd-wrap (ของเดิม) จะ skip ให้เอง */
.pw-eye-wrap {
    position: relative;
    display: inline-block;
    width: 100%;
    vertical-align: top;
}

.pw-eye-wrap > input[type="password"],
.pw-eye-wrap > input[type="text"] {
    padding-right: 42px !important;
    width: 100%;
}

.pw-eye-btn {
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    width: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 0;
    color: #6c757d;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
    touch-action: manipulation;
    border-radius: 0;
    padding: 0;
    margin: 0;
    z-index: 2;
    line-height: 0;
}

.pw-eye-btn:hover { color: #0d6efd; }
.pw-eye-btn:active,
.pw-eye-btn.is-show { color: #0d6efd; }

.pw-eye-btn svg {
    width: 20px;
    height: 20px;
    pointer-events: none;
    display: block;
}

.pw-eye-btn .icon-on { display: none; }
.pw-eye-btn.is-show .icon-off { display: none; }
.pw-eye-btn.is-show .icon-on { display: inline-block; }
