/* ---------- Card ---------- */
.form-login {
    margin: 6% auto 2% auto !important;
    background-color: #ffffff;
    padding: 36px 32px 28px 32px;
    border-radius: 16px;
    box-shadow: 0 4px 28px rgba(0, 0, 0, 0.13);
    width: 440px !important;
    border: none;
    box-sizing: border-box;
}

/* ---------- Title & subtitle ---------- */
.rp-title {
    text-align: center;
    font-size: 22px;
    font-weight: 700;
    color: #222222;
    margin: 0 0 8px 0;
}

.rp-subtitle {
    text-align: center;
    font-size: 13px;
    color: #3ba8c8;
    margin: 0 0 22px 0;
    line-height: 1.5;
}

/* ---------- Input wrapper ---------- */
.rp-field-wrap {
    position: relative;
    width: 100%;
}

.rp-input {
    width: 100% !important;
    padding: 12px 44px 12px 14px !important;
    border: 1.5px solid #d0d0d0 !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    color: #333333 !important;
    background-color: #ffffff !important;
    box-sizing: border-box !important;
    outline: none !important;
    font-family: inherit !important;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.rp-input:focus {
    border-color: #3ba8c8 !important;
    box-shadow: 0 0 0 3px rgba(59, 168, 200, 0.14) !important;
}

/* ---------- Eye button ---------- */
.rp-eye-btn {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: #999999;
    line-height: 1;
    outline: none;
    z-index: 1;
}

.rp-eye-btn:hover { color: #3ba8c8; }

/* ---------- Requirements list ---------- */
.rp-requisitos {
    list-style: none;
    padding: 10px 0 4px 0;
    margin: 0;
}

.req-item {
    font-size: 12px;
    padding: 2px 0;
    display: flex;
    align-items: center;
    transition: color 0.25s;
}

.req-fail         { color: #e07b39; }
.req-fail::before { content: '\00D7'; font-weight: 700; font-size: 15px; margin-right: 7px; min-width: 14px; color: #e07b39; }
.req-ok           { color: #4caf50; }
.req-ok::before   { content: '\2713'; font-weight: 700; font-size: 13px; margin-right: 7px; min-width: 14px; color: #4caf50; }

/* ---------- Strength bar ---------- */
.rp-strength-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 6px 0 2px 0;
}

.rp-strength-track {
    flex: 1;
    height: 6px;
    background-color: #e8e8e8;
    border-radius: 3px;
    overflow: hidden;
}

.rp-strength-fill {
    height: 100%;
    width: 0%;
    border-radius: 3px;
    transition: width 0.4s ease, background-color 0.4s ease;
}

.rp-strength-label {
    font-size: 12px;
    min-width: 42px;
    text-align: right;
}

/* ---------- Submit button ---------- */
.rp-btn,
.rp-btn.ui-button {
    display: block !important;
    width: 100% !important;
    margin-top: 22px !important;
    padding: 13px !important;
    background-color: #3ba8c8 !important;
    background-image: none !important;
    border: none !important;
    border-radius: 30px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    cursor: pointer !important;
    text-align: center !important;
    transition: background-color 0.2s !important;
    box-shadow: none !important;
}

.rp-btn:hover,
.rp-btn.ui-button:hover {
    background-color: #2d8aaa !important;
}

.rp-btn:focus,
.rp-btn.ui-button:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(59, 168, 200, 0.3) !important;
}

/* ---------- Radio group (passos) ---------- */
.rp-radio.ui-selectoneradio td {
    padding: 6px 0;
}

.rp-radio .ui-radiobutton .ui-radiobutton-box.ui-state-active {
    border-color: #3ba8c8 !important;
    background: #3ba8c8 !important;
}

.rp-radio .ui-radiobutton-label {
    font-size: 14px;
    color: #333333;
    cursor: pointer;
    margin-left: 4px;
}

/* ---------- Info / status cards ---------- */
.rp-info-text {
    text-align: center;
    font-size: 14px;
    color: #555;
    line-height: 1.6;
    margin: 0 0 10px 0;
}

.rp-info-hint {
    text-align: center;
    font-size: 12px;
    color: #888;
    margin-top: 10px;
    line-height: 1.6;
}
