/* ============================================================
   password-reset.css
   Page-local primitives for forgot-password.php + reset-password.php.
   Rides on top of /Logpage/Loginpage.css for the two-panel shell.
   All colors come from /App/assets/css/root-variables.css design tokens
   so dark mode works out of the box.
   ============================================================ */

/* ── Alert / message box ──────────────────────────────────── */
.pr-message {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 13px 16px;
    margin: 14px 0;
    border-radius: var(--radius-lg, 10px);
    font-size: 13.5px;
    line-height: 1.5;
    font-weight: 500;
    width: 100%;
    text-align: left;
    border: 1px solid transparent;
    animation: pr-slidein 0.35s ease-out;
}
.pr-message[data-tone="success"] {
    color: var(--success-700);
    background: var(--success-50);
    border-color: var(--success-200, var(--success-500));
}
.pr-message[data-tone="error"] {
    color: var(--danger-700);
    background: var(--danger-50);
    border-color: var(--danger-200, var(--danger-500));
}
.pr-message[data-tone="warning"] {
    color: var(--warning-700);
    background: var(--warning-50);
    border-color: var(--warning-200, var(--warning-500));
}
.pr-message[data-tone="info"] {
    color: var(--info-700, var(--primary-700));
    background: var(--info-50, var(--primary-100));
    border-color: var(--info-200, var(--primary-300));
}
.pr-message-icon {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.pr-message-icon svg { width: 18px; height: 18px; }
.pr-message-text { flex: 1; }
.pr-message-text strong { font-weight: 600; }
.pr-message-text ul {
    margin: 6px 0 0;
    padding-left: 18px;
    list-style: disc;
}

@keyframes pr-slidein {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Inline loading state for submit button ───────────────── */
.pr-loading {
    display: none;
    align-items: center;
    gap: 8px;
    margin: 12px 0;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 500;
}
.pr-loading.is-active { display: inline-flex; }
.pr-spinner {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--secondary-200, var(--bg-subtle));
    border-top-color: var(--primary-600);
    animation: pr-spin 0.75s linear infinite;
}
@keyframes pr-spin {
    to { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce) {
    .pr-spinner { animation: none; }
}

/* ── Password requirements ────────────────────────────────── */
.pr-requirements {
    width: 100%;
    margin: 14px 0 18px;
    padding: 14px 16px;
    background: var(--bg-subtle, var(--secondary-100));
    border: 1px solid var(--border-subtle, var(--secondary-200));
    border-radius: var(--radius-lg, 10px);
    font-size: 13px;
}
.pr-requirements-title {
    margin: 0 0 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}
.pr-requirements-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px 16px;
}
.pr-requirements-list li {
    position: relative;
    padding-left: 22px;
    color: var(--text-secondary);
    font-size: 12.5px;
    transition: color 0.15s ease;
}
.pr-requirements-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 2px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--bg-white);
    border: 1.5px solid var(--secondary-300, var(--border-subtle));
    transition: all 0.2s ease;
}
.pr-requirements-list li.is-met {
    color: var(--success-700);
}
.pr-requirements-list li.is-met::before {
    background: var(--success-500);
    border-color: var(--success-500);
}
.pr-requirements-list li.is-met::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 5px;
    width: 6px;
    height: 3px;
    border-left: 1.6px solid #fff;
    border-bottom: 1.6px solid #fff;
    transform: rotate(-45deg);
}

@media (max-width: 480px) {
    .pr-requirements-list { grid-template-columns: 1fr; }
}

/* ── Password-strength meter ──────────────────────────────── */
.pr-strength {
    margin-top: 8px;
    font-size: 12px;
}
.pr-strength-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px;
    margin-bottom: 6px;
}
.pr-strength-bar-cell {
    height: 4px;
    border-radius: 2px;
    background: var(--secondary-200, var(--border-subtle));
    transition: background 0.2s ease;
}
.pr-strength[data-level="1"] .pr-strength-bar-cell:nth-child(-n+1) { background: var(--danger-500); }
.pr-strength[data-level="2"] .pr-strength-bar-cell:nth-child(-n+2) { background: var(--warning-500); }
.pr-strength[data-level="3"] .pr-strength-bar-cell:nth-child(-n+3) { background: var(--primary-500); }
.pr-strength[data-level="4"] .pr-strength-bar-cell:nth-child(-n+4) { background: var(--success-500); }
.pr-strength-label {
    color: var(--text-secondary);
    font-weight: 500;
    min-height: 14px;
}
.pr-strength[data-level="1"] .pr-strength-label { color: var(--danger-600); }
.pr-strength[data-level="2"] .pr-strength-label { color: var(--warning-700); }
.pr-strength[data-level="3"] .pr-strength-label { color: var(--primary-600); }
.pr-strength[data-level="4"] .pr-strength-label { color: var(--success-700); }

/* ── Confirm-match indicator ──────────────────────────────── */
.pr-match {
    margin-top: 6px;
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    min-height: 14px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.pr-match[data-state="ok"]   { color: var(--success-700); }
.pr-match[data-state="bad"]  { color: var(--danger-700); }
.pr-match-icon { width: 12px; height: 12px; }

/* ── Show/hide password toggle ────────────────────────────── */
.pr-pw-toggle {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: 0;
    padding: 4px;
    cursor: pointer;
    color: var(--text-tertiary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: color 0.15s ease, background 0.15s ease;
}
.pr-pw-toggle:hover { color: var(--text-primary); background: var(--bg-subtle); }
.pr-pw-toggle:focus-visible {
    outline: 2px solid var(--primary-400);
    outline-offset: 1px;
}
.pr-pw-toggle svg { width: 18px; height: 18px; }
.pr-pw-toggle .pr-pw-eye-off { display: none; }
.pr-pw-toggle[data-shown="true"] .pr-pw-eye-on  { display: none; }
.pr-pw-toggle[data-shown="true"] .pr-pw-eye-off { display: inline; }

/* Make sure inputs leave room for the toggle. */
.pr-pw-wrap { position: relative; }
.pr-pw-wrap input { padding-right: 38px; }

/* ── Back-to-login link ───────────────────────────────────── */
.pr-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 18px;
    font-size: 13.5px;
    color: var(--text-secondary);
    text-decoration: none;
    transition: color 0.15s ease;
}
.pr-back:hover { color: var(--primary-600); }
.pr-back svg { width: 14px; height: 14px; }

/* ── Compact info pill for expiry / token-state details ───── */
.pr-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    background: var(--bg-subtle, var(--secondary-100));
    color: var(--text-secondary);
    border: 1px solid var(--border-subtle, var(--secondary-200));
}
.pr-pill svg { width: 12px; height: 12px; }
