.auth-wrapper{justify-content:center;align-items:center;min-height:calc(100vh - 200px);margin:0 auto;padding:2rem;display:flex}.auth-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 2px 8px #00000014}.auth-header{text-align:center;margin-bottom:1.5rem}.auth-header h2{color:#212529;margin-top:0;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.auth-header p{color:var(--text-muted);margin-bottom:0;font-size:.9rem}.auth-toggle{background:var(--bg-color);border:1px solid var(--border-color);border-radius:6px;margin-bottom:1.5rem;display:flex;overflow:hidden}.toggle-btn{text-align:center;cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;flex:1;padding:.6rem;font-size:.95rem;font-weight:500;transition:background-color .15s,color .15s}.toggle-btn.active{background:var(--primary-color);color:#fff}.auth-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.3rem;display:flex}.form-group label{color:#495057;font-size:.875rem;font-weight:600}.form-group input{border:1px solid var(--border-color);color:var(--text-color);background:#fff;border-radius:4px;padding:.6rem .75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus{border-color:var(--primary-color);outline:0;box-shadow:0 0 0 3px #6c757d33}.checkbox-label{color:#495057;cursor:pointer;align-items:flex-start;gap:.5rem;font-size:.875rem;font-weight:400;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;width:1rem;height:1rem;margin-top:.15rem}.checkbox-label a{font-size:.8rem;text-decoration:underline}#auth-turnstile-container,#forgot-turnstile-container,#reset-turnstile-container{justify-content:center;margin:1rem 0 .75rem;display:flex}@media (width<=400px){#auth-turnstile-container,#forgot-turnstile-container,#reset-turnstile-container{margin-left:-2.5rem;margin-right:-2.5rem}}.form-error{color:var(--danger-color);text-align:center;background:#dc354514;border-radius:4px;margin-top:.25rem;padding:.5rem;font-size:.85rem;display:none}.btn-submit{width:100%;margin-top:.5rem;padding:.65rem;font-size:1rem}.btn-forgot-link{color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:none;width:100%;padding:.25rem 0;font-size:.85rem;text-decoration:underline}.btn-forgot-link:hover{color:var(--text-color)}.success-banner{color:#1a5c2e;text-align:center;background:#d1f0da;border:1px solid #a3d9b1;border-radius:4px;margin-bottom:1rem;padding:.6rem .75rem;font-size:.875rem}.success-text{color:#1a5c2e;text-align:center;font-size:.9rem}.otp-input{letter-spacing:.4em;text-align:center;padding:.75rem;font-size:1.75rem}.resend-section{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.resend-section p{margin:0 0 .5rem}.resend-section .btn{padding:.4rem 1rem;font-size:.875rem}.resend-message{margin-top:.5rem;font-size:.85rem}