.auth-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:3rem 1rem}.auth-card{width:100%;max-width:480px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-xs)}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon-wrap{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;background:var(--color-accent-soft);display:flex;align-items:center;justify-content:center}.auth-title{font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:.35rem;letter-spacing:-.02em}.auth-subtitle{font-size:.88rem;color:var(--color-text-secondary);line-height:1.6}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.65rem;padding:.8rem 1rem;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:var(--color-text);cursor:pointer;transition:all .15s ease;font-family:Inter,sans-serif}.google-btn:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt);box-shadow:var(--shadow-xs)}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;font-family:Space Grotesk,sans-serif}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}@media(max-width:480px){.auth-row-2{grid-template-columns:1fr}}.auth-field{display:flex;flex-direction:column;gap:.35rem}.auth-label{font-size:.78rem;font-weight:600;color:var(--color-text-secondary);font-family:Space Grotesk,sans-serif}.req{color:var(--color-sale)}.auth-input{padding:.75rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.88rem;color:var(--color-text);background:var(--color-surface-alt);outline:none;font-family:Inter,sans-serif;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.auth-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.auth-input::placeholder{color:var(--color-text-muted)}.auth-password-wrap{position:relative}.auth-password-wrap .auth-input{padding-right:2.75rem}.auth-password-toggle{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.2rem;transition:color .15s ease;display:flex;align-items:center}.auth-password-toggle:hover{color:var(--color-text-secondary)}.password-strength{display:flex;align-items:center;gap:.65rem}.strength-bar{flex:1;height:4px;background:var(--color-surface-alt);border-radius:2px;overflow:hidden}.strength-fill{height:100%;border-radius:2px;transition:width .3s ease,background .3s ease;width:0%}.strength-text{font-size:.72rem;font-weight:600;font-family:Space Grotesk,sans-serif;white-space:nowrap}.auth-agree{display:flex;align-items:flex-start;gap:.65rem;cursor:pointer}.agree-checkbox{width:18px;height:18px;margin-top:.1rem;accent-color:var(--color-accent);flex-shrink:0}.agree-text{font-size:.82rem;color:var(--color-text-secondary);line-height:1.5}.agree-text a{color:var(--color-accent);text-decoration:none;font-weight:600}.agree-text a:hover{text-decoration:underline}.auth-error{background:var(--color-sale-soft);border:1px solid rgba(220,38,38,.2);border-radius:var(--radius-sm);padding:.65rem .85rem;font-size:.82rem;color:var(--color-sale);font-weight:500}.auth-success{background:var(--color-success-soft);border:1px solid rgba(22,163,74,.2);border-radius:var(--radius-sm);padding:.65rem .85rem;font-size:.82rem;color:var(--color-success);font-weight:500}.auth-submit-btn{width:100%;padding:.8rem;justify-content:center;font-size:.92rem;margin-top:.5rem}.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.auth-footer p{font-size:.85rem;color:var(--color-text-secondary)}.auth-link{color:var(--color-accent);font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}
