/* externalized from recover.html (CSP: no inline) */
.rec-wrap { max-width: 640px; margin: 0 auto; padding: 0 24px 64px; }
.rec-wrap h1 { font-family: var(--serif); font-size: 34px; font-weight: 500; margin: 32px 0 8px; }
.rec-lede { font-size: 16px; color: var(--ink-2); line-height: 1.7; margin: 0 0 28px; }
.rec-form { background: rgba(74,154,115,0.04); border: 1px solid var(--line-soft); border-radius: 8px; padding: 24px; }
.rec-form label { display: block; font-size: 13px; color: var(--muted-2); letter-spacing: 0.04em; text-transform: uppercase; margin-top: 14px; margin-bottom: 6px; }
.rec-form input { width: 100%; padding: 11px 14px; border: 1px solid var(--line-soft); border-radius: 4px; font: inherit; font-size: 15px; background: var(--paper-soft); color: var(--ink); box-sizing: border-box; }
.rec-form input:focus { outline: none; border-color: var(--confirm); }
.rec-form .hint { font-size: 12.5px; color: var(--muted); margin: 4px 0 0; font-style: italic; }
.rec-form .submit { margin-top: 22px; padding: 12px 26px; background: #1a1a1a; color: var(--paper-soft); border: 0; border-radius: 4px; font-family: var(--serif); font-size: 15px; letter-spacing: 0.03em; cursor: pointer; }
.rec-form .submit:hover { background: #000; }
.rec-form .submit:disabled { opacity: 0.6; cursor: progress; }
#rec-result { margin-top: 18px; padding: 14px 16px; border-radius: 4px; font-size: 14.5px; line-height: 1.6; display: none; }
#rec-result.ok { background: rgba(74,154,115,0.10); border-left: 3px solid var(--confirm); color: var(--ink); }
#rec-result.err { background: rgba(176,74,58,0.10); border-left: 3px solid var(--bad); color: var(--ink); }
#rec-result.wait { background: rgba(212,168,42,0.12); border-left: 3px solid #b8860b; color: var(--ink); }
.rec-faq { margin-top: 40px; font-size: 14.5px; color: var(--ink-2); line-height: 1.7; }
.rec-faq h3 { font-family: var(--serif); font-size: 17px; font-weight: 500; color: var(--ink); margin: 24px 0 4px; }

/* inline style= attributes externalized */
.rec-eyebrow { font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin: 48px 0 8px; }
.footer-inner { text-align: center; color: var(--muted); font-size: 13px; padding: 32px 0; }
.footer-links { margin-top: 8px; }
.footer-link { color: var(--muted); }
