/* ══ MODAL ══ */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.75);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all 0.3s var(--ease-out);padding:20px}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:440px;position:relative;transform:translateY(20px) scale(0.97);transition:transform 0.4s var(--ease-expo)}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal__close{position:absolute;top:16px;right:20px;font-size:1.8rem;color:var(--text-tertiary);transition:color 0.3s}.modal__close:hover{color:var(--text-primary)}
.modal__header{margin-bottom:28px}
.modal__title{font-family:var(--font-display);font-size:1.6rem;font-weight:400;margin-bottom:6px}
.modal__subtitle{font-size:0.88rem;color:var(--text-secondary)}
.modal__footer-text{text-align:center;font-size:0.85rem;color:var(--text-tertiary);margin-top:20px}
.form-link{color:var(--electric);font-weight:500}
.password-strength{height:3px;border-radius:3px;margin-top:8px;background:var(--border);overflow:hidden}
.password-strength__bar{height:100%;border-radius:3px;transition:width 0.4s var(--ease-out),background 0.4s}
.strength-weak{width:25%;background:#e74c3c}.strength-fair{width:50%;background:#f39c12}.strength-good{width:75%;background:#3498db}.strength-strong{width:100%;background:#27ae60}

/* Alert messages in modal */
.modal__alert{padding:12px 16px;border-radius:8px;font-size:0.85rem;margin-top:16px;font-family:var(--font-body)}
.modal__alert--success{background:rgba(39,174,96,0.1);border:1px solid rgba(39,174,96,0.3);color:#27ae60}
.modal__alert--error{background:rgba(231,76,60,0.1);border:1px solid rgba(231,76,60,0.3);color:#e74c3c}
